首页 | 站长免费中心 | 新手上路 | 网站运营 | 网页制作 | 图片设计 | 动画设计 | 网页编程 | 网页特效 | 本站专题 | 虚拟主机 | 域名注册 | 网站建设 | 程序下载
       免费空间资源 | 新闻咨询 | 免费域名 | 免费网盘 | 网站推广 | 网站策划 | 建站经验 | 网站优化 | 网页代码 | 源码下载 | 音乐小偷 | 网络赚钱 | 论坛交流
网站建设
网站建设
虚拟主机
虚拟主机
域名注册
域名注册
711网络首页
站长工具
站长工具
网站源码
网站源码
站长论坛
站长论坛

 711网络 网页编程ASP代码

利用ASP得到图片大小

来源: 互联网    日期:2006-12-2
 

<% 
imgpath="a.gif"

 set  pp=new  imgInfo 
 w = pp.imgW(server.mappath(imgpath)) 
 h = pp.imgH(server.mappath(imgpath))
 set pp=nothing
 
response.write "<img src='"&imgpath&"' border=0><br>宽:"&w&";高:"&h


Class  imgInfo 
 dim  aso 
 Private  Sub  Class_Initialize 
   set  aso=CreateObject("Adodb.Stream") 
   aso.Mode=3   
   aso.Type=1   
   aso.Open   
 End  Sub 
 Private  Sub  Class_Terminate
   err.clear
   set  aso=nothing 
 End  Sub 
 
 Private  Function  Bin2Str(Bin) 
   Dim  I,  Str 
   For  I=1  to  LenB(Bin) 
     clow=MidB(Bin,I,1) 
     if  ASCB(clow)<128  then 
       Str  =  Str  &  Chr(ASCB(clow)) 
     else 
       I=I+1 
       if  I  <=  LenB(Bin)  then  Str  =  Str  &  Chr(ASCW(MidB(Bin,I,1)&clow)) 
     end  if 
   Next   
   Bin2Str  =  Str 
 End  Function 
  
 Private  Function  Num2Str(num,base,lens) 
   dim  ret 
   ret  =  "" 
   while(num>=base) 
     ret  =  (num  mod  base)  &  ret 
     num  =  (num  -  num  mod  base)/base 
   wend 
   Num2Str  =  right(string(lens,"0")  &  num  &  ret,lens) 
 End  Function 
  
 Private  Function  Str2Num(str,base) 
   dim  ret 
   ret  =  0 
   for  i=1  to  len(str) 
     ret  =  ret  *base  +  cint(mid(str,i,1)) 
   next 
   Str2Num=ret 
 End  Function 
  
 Private  Function  BinVal(bin) 
   dim  ret 
   ret  =  0 
   for  i  =  lenb(bin)  to  1  step  -1 
     ret  =  ret  *256  +  ascb(midb(bin,i,1)) 
   next 
   BinVal=ret 
 End  Function 
  
 Private  Function  BinVal2(bin) 
   dim  ret 
   ret  =  0 
   for  i  =  1  to  lenb(bin) 
     ret  =  ret  *256  +  ascb(midb(bin,i,1)) 
   next 
   BinVal2=ret 
 End  Function 
  
 Private  Function  getImageSize(filespec)   
   dim  ret(3) 
   aso.LoadFromFile(filespec) 
   bFlag=aso.read(3) 
   select  case  hex(binVal(bFlag)) 
   case  "4E5089": 
     aso.read(15) 
     ret(0)="PNG" 
     ret(1)=BinVal2(aso.read(2)) 
     aso.read(2) 
     ret(2)=BinVal2(aso.read(2)) 
   case  "464947": 
     aso.read(3) 
     ret(0)="GIF" 
     ret(1)=BinVal(aso.read(2)) 
     ret(2)=BinVal(aso.read(2)) 
   case  "535746": 
     aso.read(5) 
     binData=aso.Read(1) 
     sConv=Num2Str(ascb(binData),2  ,8) 
     nBits=Str2Num(left(sConv,5),2) 
     sConv=mid(sConv,6) 
     while(len(sConv)<nBits*4) 
       binData=aso.Read(1) 
       sConv=sConv&Num2Str(ascb(binData),2  ,8) 
     wend 
     ret(0)="SWF" 
     ret(1)=int(abs(Str2Num(mid(sConv,1*nBits+1,nBits),2)-Str2Num(mid(sConv,0*nBits+1,nBits),2))/20) 
     ret(2)=int(abs(Str2Num(mid(sConv,3*nBits+1,nBits),2)-Str2Num(mid(sConv,2*nBits+1,nBits),2))/20) 
   case  "FFD8FF": 
     do   
       do:  p1=binVal(aso.Read(1)):  loop  while  p1=255  and  not  aso.EOS 
       if  p1>191  and  p1<196  then  exit  do  else  aso.read(binval2(aso.Read(2))-2) 
       do:p1=binVal(aso.Read(1)):loop  while  p1<255  and  not  aso.EOS 
     loop  while  true 
     aso.Read(3) 
     ret(0)="JPG" 
     ret(2)=binval2(aso.Read(2)) 
     ret(1)=binval2(aso.Read(2)) 
   case  else: 
     if  left(Bin2Str(bFlag),2)="BM"  then 
       aso.Read(15) 
       ret(0)="BMP" 
       ret(1)=binval(aso.Read(4)) 
       ret(2)=binval(aso.Read(4)) 
     else 
       ret(0)="" 
     end  if 
   end  select 
   ret(3)="width="""  &  ret(1)  &"""  height="""  &  ret(2)  &"""" 
   getimagesize=ret 
 End  Function 
  
 Public Function  imgW(pic_path) 
     Set  fso1  =  server.CreateObject("Scripting.FileSystemObject") 
     If (fso1.FileExists(pic_path)) Then
   Set  f1  =  fso1.GetFile(pic_path) 
   ext=fso1.GetExtensionName(pic_path) 
   select  case  ext 
    case  "gif","bmp","jpg","png": 
     arr=getImageSize(f1.path) 
     imgW = arr(1) 
   end  select 
   Set  f1=nothing
  else
      imgW = 0
  End if  
     Set  fso1=nothing 
 End  Function 
 
 Public Function  imgH(pic_path) 
     Set  fso1  =  server.CreateObject("Scripting.FileSystemObject")
  If (fso1.FileExists(pic_path)) Then
   Set  f1  =  fso1.GetFile(pic_path) 
   ext=fso1.GetExtensionName(pic_path) 
   select  case  ext 
    case  "gif","bmp","jpg","png": 
     arr=getImageSize(f1.path) 
     imgH = arr(2) 
   end  select 
   Set  f1=nothing 
  else
   imgH = 0
  End if 
     Set  fso1=nothing 
 End  Function 
End  Class
%>

 

附[2004-11-09 22:10]:刚才有朋友说如果imgpath="a.JPG",这里写调用的时候如果是大写的扩展名就取不出尺寸来了,我试了一下确实存在此问题,其实只要在case  "gif","bmp","jpg","png","JPG","GIF":加上就可以了!



更多的利用ASP得到图片大小请到论坛查看: http://BBS.TC711.COM



【 双击滚屏 】 【 评论 】 【 收藏 】 【 打印 】 【 关闭 】 来源: 互联网    日期:2006-12-2   

发 表 评 论
查看评论

  您的大名:
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款
认证编码: 刷新验证码
点评内容: 字数0
  精品推荐  
  本月推荐  
  友情赞助  

关于我们 | 联系我们 | 广告投放 | 留言反馈 | 免费程序 | 虚拟主机 | 网站建设 |  网站推广 |  google_sitemap baidu_sitemap RSS订阅
本站所有资源均来自互联网,如有侵犯您的版权或其他问题,请通知管理员,我们会在最短的时间回复您
Copyright © 2005-2015 Tc711.Com All Rights Reserved 版权所有·711网络   蜀ICP备05021915号
110网监备案 信息产业备案 不良信息举报