linux社区爱心援助Linux认证系列教程业界动态站务新闻公司招聘网络学院网址大全LPI专题CISCO专题
设为首页
加入收藏
管理团队
JSP  
JAVA  
PERL  
 您的位置:首页 > 开发语言 > ASP >
栏目导栏
  php
  JSP
  ASP
  asp.net
  JAVA
  c/c++/c#
  perl
  JavaScript
  Basic
  Delphi
资料搜索
热门文章
·由HTTP 500 Internal server e
·会员系统“找回密码”的制作方
·ASP实现数字和字母组合并生成图
·简单的asp验证码程序示例
·用ASP制作强大的搜索引擎
·如何让图片自动缩放以适合界面
·如何用foreach遍历页面上所有的
·如何实现站点的RSS输出
·无组件实现文件上传/下载
·ASP如何获取真实IP地址
·asp中如何使用 HTML 表格
·采用XMLHTTP编写一个天气预报的
·80004005错误及其解决方法
·asp中如何调试 ASP 脚本
·asp+ajax打造无刷新新闻评论系
最新文章
·ASP教程:8、ASP内建对象Respo
·ASP教程:7、ASP内建对象Reque
·ASP教程:6、ASP脚本循环语句
·ASP教程:5、ASP脚本变量、函数
·ASP教程:4、ASP脚本基础
·ASP教程:3、ASP基础
·ASP教程:2、ASP简介
·ASP教程:1、Are you ready?
·ASP中使用SQL语句教程
·ASP进度条
·由HTTP 500 Internal server e
·Asp无组件生成缩略图
·ASP 系列函数大全(4)
·ASP 系列函数大全(3)
·ASP 系列函数大全(2)
Google
 
Asp无组件生成缩略图
[ 作者:  加入时间:2007-12-03 15:49:00  来自:Linux联盟收集整理 ]
网上有不少生成缩略图的ASP组件。若你的虚拟空间不支持注册新组件,可能会感觉自己的网站失色不少。心晴不才,结合网上资源写了个无组件生成缩略图程序,仅供参考。 imcLinux联盟
   imcLinux联盟
    还是先看看基础部分吧。首先,我们知道在页面中显示图片是如下代码: imcLinux联盟
   imcLinux联盟
   imcLinux联盟
   imcLinux联盟
    <img src="pic.gif" border="0" width="300" height="260"> imcLinux联盟
   imcLinux联盟
    src是图片路径,border控制图片边缘宽度,width是图片的长度,height是图片的高度。缩略图的生成其实就是在原始尺寸上缩放。但一般为了尽量少失真,我们都会按比例缩放。于是,获取图片的长宽尺寸也就成了生成缩略图的重点。 imcLinux联盟
   imcLinux联盟
    下面便是编写无组件生成缩略图的步骤: imcLinux联盟
   imcLinux联盟
    1.无组件获取图片大小 imcLinux联盟
   imcLinux联盟
    以前刚学ASP不久时看到过一篇利用ASCII码实现无组件获取图片尺寸的文章。后来试了试,发现在获取jpg类图片尺寸时总是不能正确显示,在网上查了查,居然有不少网站转载这个程序,但没有一家指出此程序的缺陷,也就更谈不上解决缺陷的办法了。后来又google了一下,终于找到了一篇介绍利用ADODB.stream获取图片尺寸的文章,按其介绍的方法,修改里面的代码试了试,效果真的还不错,现在将其拿出来与大家分享: imcLinux联盟
   imcLinux联盟
    利用ADODB.stream获取图片尺寸的通用类 imcLinux联盟
   imcLinux联盟
  <% imcLinux联盟
  '//////////// GPS:Get Picture Size ////////////// imcLinux联盟
  '//////////////利用ADODB.stream获取图片尺寸////////////// imcLinux联盟
  '/////////Cited By Leon(心晴) 2005年8月11日////////// imcLinux联盟
   imcLinux联盟
  Class GPS imcLinux联盟
  Dim aso imcLinux联盟
   imcLinux联盟
  Private Sub Class_Initialize imcLinux联盟
  Set aso=CreateObject("Adodb.Stream") imcLinux联盟
  aso.Mode=3 imcLinux联盟
  aso.Type=1 imcLinux联盟
  aso.Open imcLinux联盟
  End Sub imcLinux联盟
   imcLinux联盟
  Private Sub Class_Terminate imcLinux联盟
  set aso=nothing imcLinux联盟
  End Sub imcLinux联盟
   imcLinux联盟
  Private Function Bin2Str(Bin) imcLinux联盟
  Dim I, Str imcLinux联盟
  For I=1 to LenB(Bin) imcLinux联盟
  clow=MidB(Bin,I,1) imcLinux联盟
  if AscB(clow)<128 then imcLinux联盟
  Str = Str & Chr(ASCB(clow)) imcLinux联盟
  Else imcLinux联盟
  I=I+1 imcLinux联盟
  if I <= LenB(Bin) then Str = Str & Chr(ASCW(MidB(Bin,I,1)&clow)) imcLinux联盟
  end If imcLinux联盟
  Next imcLinux联盟
  Bin2Str = Str imcLinux联盟
  End Function imcLinux联盟
   imcLinux联盟
  Private Function Num2Str(num,base,lens) imcLinux联盟
  'GPS (2005-8-11) imcLinux联盟
  dim ret imcLinux联盟
  ret = "" imcLinux联盟
  while(num>=base) imcLinux联盟
  ret = (num mod base) & ret imcLinux联盟
  num = (num - num mod base)/base imcLinux联盟
  wend imcLinux联盟
  Num2Str = right(string(lens,"0") & num & ret,lens) imcLinux联盟
  End Function imcLinux联盟
   imcLinux联盟
  Private Function Str2Num(str,base) imcLinux联盟
  'GPS (2005-8-11) imcLinux联盟
  dim ret imcLinux联盟
  ret = 0 imcLinux联盟
  for i=1 to len(str) imcLinux联盟
  ret = ret *base + cint(mid(str,i,1)) imcLinux联盟
  next imcLinux联盟
  Str2Num=ret imcLinux联盟
  End Function imcLinux联盟
   imcLinux联盟
  Private Function BinVal(bin) imcLinux联盟
  'GPS (2002-8-11) imcLinux联盟
  dim ret imcLinux联盟
  ret = 0 imcLinux联盟
  for i = lenb(bin) to 1 step -1 imcLinux联盟
  ret = ret *256 + ascb(midb(bin,i,1)) imcLinux联盟
  next imcLinux联盟
  BinVal=ret imcLinux联盟
  End Function imcLinux联盟
   imcLinux联盟
  Private Function BinVal2(bin) imcLinux联盟
  'GPS (2002-8-11) imcLinux联盟
  dim ret imcLinux联盟
  ret = 0 imcLinux联盟
  for i = 1 to lenb(bin) imcLinux联盟
  ret = ret *256 + ascb(midb(bin,i,1)) imcLinux联盟
  next imcLinux联盟
  BinVal2=ret imcLinux联盟
  End Function imcLinux联盟
   imcLinux联盟
  '///以下是调用代码/// imcLinux联盟
  Function getImageSize(filespec) imcLinux联盟
  'GPS (2002-8-11) imcLinux联盟
  dim ret(3) imcLinux联盟
  aso.LoadFromFile(filespec) imcLinux联盟
  bFlag=aso.read(3) imcLinux联盟
  select case hex(binVal(bFlag)) imcLinux联盟
  case "4E5089": imcLinux联盟
  aso.read(15) imcLinux联盟
  ret(0)="PNG" imcLinux联盟
  ret(1)=BinVal2(aso.read(2)) imcLinux联盟
  aso.read(2) imcLinux联盟
  ret(2)=BinVal2(aso.read(2)) imcLinux联盟
  case "464947": imcLinux联盟
  aso.read(3) imcLinux联盟
  ret(0)="GIF" imcLinux联盟
  ret(1)=BinVal(aso.read(2)) imcLinux联盟
  ret(2)=BinVal(aso.read(2)) imcLinux联盟
  case "535746": imcLinux联盟
  aso.read(5) imcLinux联盟
  binData=aso.Read(1) imcLinux联盟
  sConv=Num2Str(ascb(binData),2 ,8) imcLinux联盟
  nBits=Str2Num(left(sConv,5),2) imcLinux联盟
  sConv=mid(sConv,6) imcLinux联盟
  while(len(sConv)<nBits*4) imcLinux联盟
  binData=aso.Read(1) imcLinux联盟
  sConv=sConv&Num2Str(ascb(binData),2 ,8) imcLinux联盟
  wend imcLinux联盟
  ret(0)="SWF" imcLinux联盟
  ret(1)=int(abs(Str2Num(mid(sConv,1*nBits+1,nBits),2)-Str2Num(mid(sConv,0*nBits+1,nBits),2))/20) imcLinux联盟
  ret(2)=int(abs(Str2Num(mid(sConv,3*nBits+1,nBits),2)-Str2Num(mid(sConv,2*nBits+1,nBits),2))/20) imcLinux联盟
  case "FFD8FF": imcLinux联盟
  do imcLinux联盟
  do: p1=binVal(aso.Read(1)): loop while p1=255 and not aso.EOS imcLinux联盟
  if p1>191 and p1<196 then exit do else aso.read(binval2(aso.Read(2))-2) imcLinux联盟
  do:p1=binVal(aso.Read(1)):loop while p1<255 and not aso.EOS imcLinux联盟
  loop while true imcLinux联盟
  aso.Read(3) imcLinux联盟
  ret(0)="JPG" imcLinux联盟
  ret(2)=binval2(aso.Read(2)) imcLinux联盟
  ret(1)=binval2(aso.Read(2)) imcLinux联盟
  case else: imcLinux联盟
  if left(Bin2Str(bFlag),2)="BM" then imcLinux联盟
  aso.Read(15) imcLinux联盟
  ret(0)="BMP" imcLinux联盟
  ret(1)=binval(aso.Read(4)) imcLinux联盟
  ret(2)=binval(aso.Read(4)) imcLinux联盟
  else imcLinux联盟
  ret(0)="" imcLinux联盟
  end if imcLinux联盟
  end select imcLinux联盟
  ret(3)="width=""" & ret(1) &""" height=""" imcLinux联盟
  & ret(2) &"""" imcLinux联盟
  getimagesize=ret imcLinux联盟
  End Function imcLinux联盟
  End Class imcLinux联盟
  %> imcLinux联盟
   imcLinux联盟
    将以上代码复制生成GPS.asp文件,这样无组件获取图片尺寸的通用类就OK了。 imcLinux联盟
2.获取图片路径 imcLinux联盟
   imcLinux联盟
    由于不只一张图片,以及图片需分类存放,我们在数据库中设计了一个存放图片相对路径的字段ImgURL。我们把上传的图片都放在一个名为images的文件夹中(至于如何无组件上传图片心晴就不在多说了)。现在我们先设计一个ShowImg.ASP页面用来显示缩略图及相关信息。具体设计如下: imcLinux联盟
   imcLinux联盟
    图片: imcLinux联盟
   imcLinux联盟
    图片格式: imcLinux联盟
   imcLinux联盟
    图片尺寸: imcLinux联盟
   imcLinux联盟
    图片大小: imcLinux联盟
   imcLinux联盟
    点击次数: imcLinux联盟
   imcLinux联盟
    下面,我们获取图片的绝对路径。代码如下: imcLinux联盟
   imcLinux联盟
  <% imcLinux联盟
  '/////获取ShowImg.asp的绝对路径///// imcLinux联盟
  Dim curFile imcLinux联盟
  curFile=Server.mappath(Request.servervariables("PATH_INFO")) imcLinux联盟
  Dim curfilename,filename imcLinux联盟
   imcLinux联盟
  '/////图片相对路径(存于数据库中) imcLinux联盟
  cufilename=rs("ImgURL") imcLinux联盟
   imcLinux联盟
  '/////因为ShowImg.asp与images在同一目录,所以我们用instrrev获取images的路径///// imcLinux联盟
  filename=left(curFile,instrrev(curFile,"\"))&cufilename imcLinux联盟
   imcLinux联盟
  '/////建立GPS类实体///// imcLinux联盟
  Dim GetPicSize imcLinux联盟
  Set GetPicSize=new GPS imcLinux联盟
  Set fs=Server.CreateObject("Scripting.FileSystemObject") imcLinux联盟
   imcLinux联盟
  '/////获取图片类型///// imcLinux联盟
  Dim PicSuffixName imcLinux联盟
  PicSuffixName=fs.GetExtensionName(filename) imcLinux联盟
  Dim PD '//Picture Dimension imcLinux联盟
  Dim PWidth,PHeight imcLinux联盟
  Select Case PicSuffixName imcLinux联盟
  Case "gif","bmp","jpg","png": imcLinux联盟
   imcLinux联盟
  '/////调用GPS通用类中的GetImageSize函数获取图片尺寸///// imcLinux联盟
  PD=GetPicSize.GetImageSize(filename) imcLinux联盟
  PWidth=PD(1) '//获取图片宽度 imcLinux联盟
  PHeight=PD(2) '//获取图片高度 imcLinux联盟
  Case "swf" imcLinux联盟
  PD=GetPicSize.GetImageSize(filename) imcLinux联盟
  PWidth=PD(1) '//获取Flash宽度 imcLinux联盟
  PHeight=PD(2) '//获取Flash高度 imcLinux联盟
  Case Else imcLinux联盟
  End Select imcLinux联盟
  Set fs=Nothing imcLinux联盟
  Set GetPicSize=Nothing imcLinux联盟
  %> imcLinux联盟
   imcLinux联盟
   imcLinux联盟
    将上面的代码复制到<body>的上面就OK了! imcLinux联盟
   imcLinux联盟
    当然,有人会说,获取路径不一定要用PATH_INFO,直接用server.mappath()不就可以了嘛,呵呵,萝卜青菜各有所爱,主要是我用PATH_INFO可以实现FSO的一些功能而用server.mappath()没有搞定,所以一直使用这个。 imcLinux联盟
3.定义缩略图尺寸 imcLinux联盟
   imcLinux联盟
    这部分代码就是仁者见仁,智者见智了。首先,我们需要规定缩略图显示尺寸范围,譬如:300X260,代码可以这样写: imcLinux联盟
   imcLinux联盟
  <% imcLinux联盟
  Dim PXWidth,PXHeight imcLinux联盟
  Dim Pp '//Proportion imcLinux联盟
  If PWidth=0 Or PWidth="" Then imcLinux联盟
  PXWidth=0 imcLinux联盟
  PXHeight=0 imcLinux联盟
  Else imcLinux联盟
  Pp=FormatNumber(PWidth/PHeight,2) '//长宽比 imcLinux联盟
  End If imcLinux联盟
  If PWidth>=PHeight Then imcLinux联盟
  If PWidth>=300 Then imcLinux联盟
  PXWidth=300 imcLinux联盟
  PXHeight=FormatNumber(300/Pp,0) imcLinux联盟
  Else imcLinux联盟
  PXWidth=PWidth imcLinux联盟
  PXHeight=PHeight imcLinux联盟
  End If imcLinux联盟
  Else imcLinux联盟
  If PHeight>=260 Then imcLinux联盟
  PXHeight=260 imcLinux联盟
  PXWidth=FormatNumber(260*Pp,0) imcLinux联盟
  Else imcLinux联盟
  PXWidth=PWidth imcLinux联盟
  PXHeight=PHeight imcLinux联盟
  End If imcLinux联盟
  End If imcLinux联盟
  %> imcLinux联盟
   imcLinux联盟
   imcLinux联盟
    将上面的代码紧接第二步写下即可。调用时代码如下: imcLinux联盟
   imcLinux联盟
  <img src=<%=curfilename%> border="0" width=<%=PXWidth%> imcLinux联盟
  height=<%=PXHeight%>> imcLinux联盟
   imcLinux联盟
   imcLinux联盟
    至于图片格式可以用得到,图片尺寸可以写成 imcLinux联盟
   imcLinux联盟
  <% imcLinux联盟
  response.write PXWidth&"X"&PXHeight imcLinux联盟
  %> imcLinux联盟
   imcLinux联盟
   imcLinux联盟
    图片大小可以用FSO.GetFileSize(filename)来实现,而点击次数可以简单地用SQL语句实现,具体编码就不再累述了。 imcLinux联盟
   imcLinux联盟
    这样,一个无组件生成缩略图程序就写好了,可能有点拿来主义,不过只要大家能将方法掌握相信还是有很大提高的。 imcLinux联盟
Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论
评论】【加入收藏夹】【 】【打印】【关闭
※ 相关链接
 ·ASP 系列函数大全(4)  (2007-12-03 15:48:33)
 ·ASP 系列函数大全(3)  (2007-12-03 15:47:58)
 ·ASP 系列函数大全(2)  (2007-12-03 15:47:25)
 ·ASP 系列函数大全(1)  (2007-12-03 15:46:53)
 ·用ASP制作强大的搜索引擎  (2007-12-03 15:45:48)
 ·实例讲解asp抓取网上房产信息  (2007-12-03 15:44:50)
 ·如何写出优秀的ASP应用  (2007-12-03 15:40:32)
 ·asp内置对象 ObjectContext详解  (2007-12-03 15:39:31)
 ·asp存贮过程  (2007-12-03 15:38:32)
 ·asp内置对象Application详解  (2007-12-03 15:38:01)