开店乐

开店乐电子商务研究 KaiDianLe.Com

网站地图 :

  搜索:

Asp无组件生成缩略图

    

网上有不少生成缩略图的ASP组件。若你的虚拟空间不支持注册新组件,可能会感觉自己的网站失色不少。心晴不才,结合网上资源写了个无组件生成缩略图程序,仅供参考。
  
    还是先看看基础部分吧。首先,我们知道在页面中显示图片是如下代码:
  
  
  
    <img src="pic.gif" border="0" width="300" height="260">
  
    src是图片路径,border控制图片边缘宽度,width是图片的长度,height是图片的高度。缩略图的生成其实就是在原始尺寸上缩放。但一般为了尽量少失真,我们都会按比例缩放。于是,获取图片的长宽尺寸也就成了生成缩略图的重点。
  
    下面便是编写无组件生成缩略图的步骤:
  
    1.无组件获取图片大小
  
    以前刚学ASP不久时看到过一篇利用ASCII码实现无组件获取图片尺寸的文章。后来试了试,发现在获取jpg类图片尺寸时总是不能正确显示,在网上查了查,居然有不少网站转载这个程序,但没有一家指出此程序的缺陷,也就更谈不上解决缺陷的办法了。后来又google了一下,终于找到了一篇介绍利用ADODB.stream获取图片尺寸的文章,按其介绍的方法,修改里面的代码试了试,效果真的还不错,现在将其拿出来与大家分享:
  
    利用ADODB.stream获取图片尺寸的通用类
  
  <%
  '//////////// GPS:Get Picture Size //////////////
  '//////////////利用ADODB.stream获取图片尺寸//////////////
  '/////////Cited By Leon(心晴) 2005年8月11日//////////
  
  Class GPS
  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
  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)
  'GPS (2005-8-11)
  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)
  'GPS (2005-8-11)
  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)
  'GPS (2002-8-11)
  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)
  'GPS (2002-8-11)
  dim ret
  ret = 0
  for i = 1 to lenb(bin)
  ret = ret *256 + ascb(midb(bin,i,1))
  next
  BinVal2=ret
  End Function
  
  '///以下是调用代码///
  Function getImageSize(filespec)
  'GPS (2002-8-11)
  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
  End Class
  %>
  
    将以上代码复制生成GPS.asp文件,这样无组件获取图片尺寸的通用类就OK了。【来源:开店乐KaiDianLe.Com

 2.获取图片路径
  
    由于不只一张图片,以及图片需分类存放,我们在数据库中设计了一个存放图片相对路径的字段ImgURL。我们把上传的图片都放在一个名为images的文件夹中(至于如何无组件上传图片心晴就不在多说了)。现在我们先设计一个ShowImg.ASP页面用来显示缩略图及相关信息。具体设计如下:
  
    图片:
  
    图片格式:
  
    图片尺寸:
  
    图片大小:
  
    点击次数:
  
    下面,我们获取图片的绝对路径。代码如下:
  
  <%
  '/////获取ShowImg.asp的绝对路径/////
  Dim curFile
  curFile=Server.mappath(Request.servervariables("PATH_INFO"))
  Dim curfilename,filename
  
  '/////图片相对路径(存于数据库中)
  cufilename=rs("ImgURL")
  
  '/////因为ShowImg.asp与images在同一目录,所以我们用instrrev获取images的路径/////
  filename=left(curFile,instrrev(curFile,"\"))&cufilename
  
  '/////建立GPS类实体/////
  Dim GetPicSize
  Set GetPicSize=new GPS
  Set fs=Server.CreateObject("Scripting.FileSystemObject")
  
  '/////获取图片类型/////
  Dim PicSuffixName
  PicSuffixName=fs.GetExtensionName(filename)
  Dim PD '//Picture Dimension
  Dim PWidth,PHeight
  Select Case PicSuffixName
  Case "gif","bmp","jpg","png":
  
  '/////调用GPS通用类中的GetImageSize函数获取图片尺寸/////
  PD=GetPicSize.GetImageSize(filename)
  PWidth=PD(1) '//获取图片宽度
  PHeight=PD(2) '//获取图片高度
  Case "swf"
  PD=GetPicSize.GetImageSize(filename)
  PWidth=PD(1) '//获取Flash宽度
  PHeight=PD(2) '//获取Flash高度
  Case Else
  End Select
  Set fs=Nothing
  Set GetPicSize=Nothing
  %>
  
  
    将上面的代码复制到<body>的上面就OK了!
  
    当然,有人会说,获取路径不一定要用PATH_INFO,直接用server.mappath()不就可以了嘛,呵呵,萝卜青菜各有所爱,主要是我用PATH_INFO可以实现FSO的一些功能而用server.mappath()没有搞定,所以一直使用这个。

3.定义缩略图尺寸
  
    这部分代码就是仁者见仁,智者见智了。首先,我们需要规定缩略图显示尺寸范围,譬如:300X260,代码可以这样写:
  
  <%
  Dim PXWidth,PXHeight
  Dim Pp '//Proportion
  If PWidth=0 Or PWidth="" Then
  PXWidth=0
  PXHeight=0
  Else
  Pp=FormatNumber(PWidth/PHeight,2) '//长宽比
  End If
  If PWidth>=PHeight Then
  If PWidth>=300 Then
  PXWidth=300
  PXHeight=FormatNumber(300/Pp,0)
  Else
  PXWidth=PWidth
  PXHeight=PHeight
  End If
  Else
  If PHeight>=260 Then
  PXHeight=260
  PXWidth=FormatNumber(260*Pp,0)
  Else
  PXWidth=PWidth
  PXHeight=PHeight
  End If
  End If
  %>
  
  
    将上面的代码紧接第二步写下即可。调用时代码如下:
  
  <img src=<%=curfilename%> border="0" width=<%=PXWidth%>
  height=<%=PXHeight%>>
  
  
    至于图片格式可以用得到,图片尺寸可以写成
  
  <%
  response.write PXWidth&"X"&PXHeight
  %>
  
  
    图片大小可以用FSO.GetFileSize(filename)来实现,而点击次数可以简单地用SQL语句实现,具体编码就不再累述了。
  
    这样,一个无组件生成缩略图程序就写好了,可能有点拿来主义,不过只要大家能将方法掌握相信还是有很大提高的。

【日期:2006-8-7】【作者:不祥】【转载自:开店乐】

相关文章:
 最好的网上开店系统:凡人网络购物系统免费下载
 Rs.open sql,conn,A,B 的A、B各代表什么?
 ASP开发中存储过程应用全接触
 Oracle大文本在ASP中存取问题的解决
 数据分页方法新思路,速度非常快!
 ASP+vbscript写的万能查询表达式生成器
 常用网站数据库SQL操作语句
 ASP程序与SQL存储过程详解
 ASP脚本一空间绑定多个域名代码
 WEB编程开发常用的代码大全
 解决大字段在Form中Post出错的方法
 学习ASP之编写安全的ASP代码
 ASP程序应用之模板采用
 防止别人批量采集功能的ASP代码
 网页图片下拉选择控件使用实例
 平时写程序的时候出错时的解决方法
 “在线访客”的制作方法
 ASP中数据库调用时常见错误的现象和解决
 ASP 编程中20个非常有用的例子
 经典实用的基础asp程序整理
 ASP中从数据库读取二进制文件数据代码
 ASP动态生成的javascript表单验证代码
 在电子商务中实现购物车的方法
 ASP利用Google实现在线翻译功能
 实现千万级数据分页的存储过程
 详细说明用ASP和WML来实现数据库查询
 ASP访问INTERBASE数据库
 ASP安全配置不完全手册
 在ASP中如何访问Novell下的数据库
 ASP进阶学习必经之认识数学函数11种
 初学者必读 ASP运行环境的搭建
 解析asp的脚本语言
 学习使用ASP对象和组件
 让ASP程序运行于非Windows平台
 通过启动脚本来感受ASP的力量
 一些不长见的ASP调用存储过程的技巧
 使用ASP脚本技术
 优化Web数据库页面
 Asp限制IP访问代码
 ACCESS数据库防下载另类方法
 ASP浏览器性能组件
 细说ASP中Counters 组件
 全面解析Server对象
 ASP 内建对象Request和Respones
 深入研究Application和Session对象
 使用ASP、VB和XML建立运行于互联网上的应用程序
 在客户端执行数据库记录的分页显示
 对ASP脚本源代码进行加密
 用代码打开Access文件的两种方法
 使用Visual InterDev进行小组开发
 用JScript脚本实现分页的另类办法
 ASP中Cookie读写的实现方法
 如何使用ASP建立虚拟的FTP服务器
 在ASP中自动创建多级文件夹的函数
 一个硬盘文件搜索的Asp源码
 ASP使用MYSQL数据库全攻略
 ASP上传数据流格式分析详解
 ASP汉字转换UTF-8及UTF-8转换GB2312
 ASP常用数据库连接及操作的方法
 ASP编程中常用SQL命令使用方法
 ASP查询记录时RecordCount=-1问题
 让你的WAP网站有更好的兼容性
 如何注册服务器端组件
 轻松实现任何程序和动易整合
 在服务器端调用winzip命令行对上传的多个文件打包压缩
 用ASP制作强大的搜索引擎
 ASP彩色校验码的制作
 ASP 系列函数大全
 ASP程序处理进程进度条
 Asp无组件生成缩略图
 用ASP实现自动建站.实现虚拟二级目录
 删除Access数词库中的空记录
 ASP身份证验证代码函数
 ASP写的自动生成SELECT表单的函数
 几种打开记录集方式的比较
 用ASP实现汉字转拼音的功能
 ASP分页代码,已经写成类了,值得参考
 ASP下载系统防盗链方法
 Global.asa文件用法大全
 如何防止页面中的敏感信息被提取
 Delphi编写组件封装asp代码的基本步骤
 制做行背景颜色交替变换的表格
 如何用foreach遍历页面上所有的TextBox
 将数据库中的信息存储至XML文件中
 用Asp写个加密和解密的类
 如何固定表格的标题行和标题列
 ASP小偷(远程数据获取)程序入门教程
 Asp编写不再让人讨厌的自动弹出窗口
 用ASP实现在线压缩与解压缩
 使用组件封装ASP的数据库操作
 ASP中读写注册表
 ASP判断函数一览及网页制作常用技术
 ASP中Cookie使用指南
 随机产生用户密码(good)
 ASP:如何对身份证的籍贯进行验证
 ASP产生随机密码的函数
 ASP+ADO实现数据读写简单示例
 一个简单的用户登录接口ASP实现
 ASP+SQL Server构建网页防火墙
 一个通用的保护ASP系统的方法
 利用ASP发送和接收XML数据的处理方法

版权所有:Kaidianle.Com  联系方式:Shnxn@Yhaoo.Com.Cn 京ICP备06028743号 在线留言