ASPJpeg和ASPUpload组件的一些属性和方法

时间:2022-08-28 00:26:45

自己整理出来的ASPJpeg和ASPUpload组件的一些属性和方法

aspUpload
Set Upload = Server.CreateObject("Persits.Upload")
创建对象
方法:
save "path"
保存到指定路径
如果不指定路径则保存在内存中
saveas "path"
把内存中的文件保存到指定位置
Upload.CreateDirectory Path, True
建立文件夹
Upload.OpenFile(SavePath)
打开指定路径文件进行操作
Upload.DeleteFile FilePath
删除指定文件
-------------------------------------
属性:
Set File = Upload.Files("FILE1")
创建文件对象
files
获取表单文件控件元素,可以用for each 遍历
For Each File in Upload.Files
 Response.Write File.Name & "= " & File.Path & " (" & File.Size &" bytes)<BR>"
Next
file.Filename 获取上传文件名
File.Ext 获取文件扩展名
file.path 获取上传保存路径
file.size 获取上传文件大小
File.Delete 删除已经上传的文件
File.Copy 复制一个文件到指定路径
File.ImageType 指定上传上文件类型默认为GIF, JPEG, BMP, PNG 未知UNKNOWN
File.ImageWidth 获取上传图片宽
File.ImageHeight获取上传图片高
Upload.Form 获取表单所有元素
File.MD5Hash 使用MD5加密编码,唯一值可做
File.Binary 将转换过的二进制文件写入数据库
Upload.CodePage = 65001  支持UTF-8支持中文
SetMaxSize 字节, True
最大能上传总字节,同时上传多个时计为总和
Count = Upload.Save "path"
获取上传的文件个数
 
 
一、图片缩略
<%
Set Jpeg = Server.CreateObject("Persits.Jpeg") 调用组件
Path = Server.MapPath("images") & "\clock.jpg" 待处理图片路径
Jpeg.Open Path 打开图片
高与宽为原图片的1/2
Jpeg.Width = Jpeg.OriginalWidth / 2
Jpeg.Height = Jpeg.OriginalHeight / 2
保存图片
Jpeg.Save Server.MapPath("images") & "\clock_small.jpg"
%>
<IMG SRC="images/clock_small.jpg"> 查看处理的图片
 
二、图片水印
<%
Set Jpeg = Server.CreateObject("Persits.Jpeg")
Jpeg.Open Server.MapPath("images/dodge_viper.jpg")
开始写文字
Jpeg.Canvas.Font.Color = &000000' red 颜色
Jpeg.Canvas.Font.Family = "Courier New" 字体
Jpeg.Canvas.Font.Bold = True 是否加粗
Jpeg.Canvas.Print 10, 10, "Copyright (c) XYZ, Inc."
打印坐标x 打印坐标y 需要打印的字符
以下是对图片进行边框处理
Jpeg.Canvas.Pen.Color = &H000000' black 颜色
Jpeg.Canvas.Pen.Width = 2 画笔宽度
Jpeg.Canvas.Brush.Solid = False 是否加粗处理
Jpeg.Canvas.Bar 1, 1, Jpeg.Width, Jpeg.Height
起始X坐标 起始Y坐标 输入长度 输入高度
Jpeg.Save Server.MapPath("images/dodge_viper_framed.jpg") 保存
%>
 
三、安全码
安全玛的道理和加水印差不多,很多朋友问我要具体的代码技术,在这里我就写出来和大家分享,一般人我还不告诉他。呵呵。
<%
生成安全码的函数 www.knowsky.com
function make_randomize(max_len,w_n) max_len 生成长度,w_n:0 可能包含字母,1:只为数字
randomize
for intcounter=1 to max_len
whatnext=int((1-0+1)*rnd+w_n)
if whatnext=0 then
upper=122
lower=97
else
upper=57
lower=48
end if
strnewpass=strnewpass & chr(int((upper-lower+1)*rnd)+lower)
next
make_randomize=strnewpass
end function
%>
生成安全码的图片。当然你要预先准备一张背景图哦
<%random_num=make_randomize(4,1) 生成4位数字的安全码
session("random_num")=random_num 为什么调用session,没有session的安全码是完全没有意义的。呵呵
Set Jpeg = Server.CreateObject("Persits.Jpeg") 调用组件
Jpeg.Open Server.MapPath("infos/random_pic/random_index.gif") 打开准备的图片
Jpeg.Canvas.Font.Color = &H006699
Jpeg.Canvas.Font.Family = "Arial Black"
Jpeg.Canvas.Font.Bold = false
Jpeg.Canvas.PrintText 0, -2, random_num
jpeg.save Server.MapPath("infos/random_pic/random_index.bmp") 保存
%> <img src="infos/random_pic/random_index.bmp" border="0" align="absmiddle">
自己做做看。呵呵。
 

四、图片切割
一直以来,对aspjpeg不了解的人以为是无法用它来进行切割的。
其实有这样的一个方法的
crop x1,y1,x2,y2
切割长方型左上角x坐标,y坐标 右下角x坐标 y坐标
下面我就做一个演示哈
Set Jpeg = Server.CreateObject("Persits.Jpeg")
jpeg.open server.MapPath("/pic/1.gif")
jpeg.width=70
Jpeg.Height = Jpeg.OriginalHeight*70 / jpeg.Originawidth
jpeg.crop 0,0,70,52 开始切割其实是把超过52象素的下部分去掉
jpeg.save server.MapPath("/temp_pic/small_1.gif") 保存
怎么样,很简单吧
 
五、图片合并
我们这里是要把logo图片加到dodge_viper.jpg图片上去
其实,图片合并的方法也可以用来动态打水印哦
Set Photo = Server.CreateObject("Persits.Jpeg")
PhotoPath = Server.MapPath("images") & "\dodge_viper.jpg"
Photo.Open PhotoPath
Set Logo = Server.CreateObject("Persits.Jpeg")
LogoPath = Server.MapPath("images") & "\clock.jpg"
Logo.Open LogoPath
Logo.Width = 70
Logo.Height = Logo.Width * Logo.OriginalHeight / Logo.OriginalWidth
Photo.DrawImage 0, 0, Logo
Photo.SendBinary 这里用了sendBinary的输出方法。当然,你也可以先保存更改后的dodge_viper.jpg,再输入也可以。我个人不大喜欢用sendBinary方法,在网速慢的时候容易出错。在速度方面也不怎样。呵呵。
 
六、数据库支持
这里不多说了。其实就是Binary方法,大家知道图片存进数据库只能存为二进制的文件的。所以代码就懒的写了。
 
七、更多方法介绍
Canvas.Line(Left, Top, Right, Bottom)
画一条直线
Canvas.Ellipse(Left, Top, Right, Bottom)
画出一个椭圆
Canvas.Circle(X, Y, Radius)
画出一个圆
Canvas.Bar(Left, Top, Right, Bottom)
画出一个长方形,上面有代码介绍了
Canvas.Font.ShadowColor
文字阴影颜色
Canvas.Font.ShadowXOffset As Long
阴影X坐标设定
Canvas.Font.ShadowYOffset As Long
Y坐标设定
Canvas.Font.BkMode As String
文字背景
上次做过图片水印,效果很差,没办法把图片弄成背景透明的,用背景透明gif会自动填充成白色。用去掉某种颜色的功能,图片颜色总是不纯,出来的效果斑斑点点。今天灵机一动,把这两个结合起来,用背景透明的gif,并且抽取水印底色,果然成功了!
    ogvbox.Canvas.Pen.Color  = &H000000  \\\'// 边框的颜色
    ogvbox.Canvas.Pen.Width  = 1    \\\'// 边框的粗细
    ogvbox.Canvas.Brush.Solid = False   \\\'// 图片边框内是否填充颜色
    ogvbox.DrawImage ogvbox.Width-210, ogvbox.Height-74, Logobox  ,0.3,&HFFFFFF    \\\'// 加入图片的位置坐标(添加水印图片),我用图片大小减去水印大小,把水印加在右下角。参数顺序为:水平坐标,垂直坐标,水印图片地址,水银透明度,抽取颜色(&H表示16进制)
    ogvbox.Canvas.Bar 0, 0, ogvbox.Width, ogvbox.Height \\\'// 图片边框线的位置坐标和大小
    ogvbox.Save Server.MapPath(imagename)  \\\'// 生成文件

\'//------Pollener.com AspJpeg组件的预览和水印生成------开始------
\'创建预览图片:call CreateView(原始文件的路径,预览文件名及路径)
Sub CreateView(imagename,tempFilename)
\'定义变量。
Dim PreviewImageFolderName
Dim ogvbox,objFont
Dim Logobox,LogoPath
LogoPath = Server.MapPath("images") & " \\shuiyin.gif"  \'//加入图片所在路径及文件名(我的是论坛 \\images\\shuiyin.gif)。
Select Case upload_ViewType
Case 0
\'---------------------CreatePreviewImage---------------
set ogvbox = Server.CreateObject("CreatePreviewImage.cGvbox")
ogvbox.SetSavePreviewImagePath=Server.MapPath(tempFilename)   \'预览图存放路径。
ogvbox.SetPreviewImageSize =SetPreviewImageSize      \'预览图宽度。
ogvbox.SetImageFile = trim(Server.MapPath(imagename))    \'imagename原始文件的物理路径。
\'创建预览图的文件。
If ogvbox.DoImageProcess=false Then
Response.write "生成预览图错误:"& ogvbox.GetErrString
End If
Case 1
\'---------------------AspJpegV1.2---------------
Set Logobox = Server.CreateObject("Persits.Jpeg")
\'//建议不要图片和文字水印同时使用,本代码为使用图片水印。
Logobox.Open LogoPath  \'//读取添加的图片。
\'//重新设置图片的大小。
Logobox.Width = 186  \'//用做水印的图片的宽度值(像素)。
Logobox.Height = 52  \'//用做水印的图片的高度值(像素)。
\'//添加水印。
Set ogvbox = Server.CreateObject("Persits.Jpeg")
\'//读取要处理的原文件。
ogvbox.Open Trim(Server.MapPath(imagename))
If ogvbox.OriginalWidth<Cint(ImageWidth) or ogvbox.Originalheight<Cint(ImageHeight) Then
  F_Viewname=""
  Set ogvbox = Nothing
  Exit Sub
Else
IF ImageMode<>"" and FileExt<>"gif" Then  \'//如果将这行改为IF ImageMode<>"" Then则可给上传的GIF图片也加上水印,但是那些动画的GIF在加了水印以后就只剩第一桢了,根据你的需求酌情处理吧。
\'//关于修改字体及文字颜色的。
\'//ogvbox.Canvas.Font.Color = &H0000FF  \'//水印文字的颜色,&H后面输入色彩值。
\'//ogvbox.Canvas.Font.Size = 18  \'//水印文字的大小。
\'//ogvbox.Canvas.Font.Family = "Arial"  \'//水印文字的字体名称。
\'//ogvbox.Canvas.Font.ShadowColor = &H000000  \'//水印文字的阴影色彩。
\'//ogvbox.Canvas.Font.ShadowXoffset = 1  \'//水印文字阴影向右偏移的像素值,输入负值则向左偏移。
\'//ogvbox.Canvas.Font.ShadowYoffset = 1  \'//水印文字阴影向下偏移的像素值,输入负值则向右偏移。
\'//ogvbox.Canvas.Font.Quality = 3  \'//水印文字的清晰度,从0~4,变换不是很大,建议用2或3。
\'//ogvbox.Canvas.Font.Bold = True  \'//水印文字是否为粗体,True=粗体 False=正常。
\'ogvbox.Canvas.Print 10, 10, ImageMode  \'//水印文字的起始坐标(像素)。
ogvbox.Canvas.Pen.Color  = &H000000  \'//增加水印后图片的边框色彩。
ogvbox.Canvas.Pen.Width  = 1   \'//增加水印后图片的边框宽度。
ogvbox.Canvas.Brush.Solid = False  \'//边框内是否填充颜色,你可以试试看值为True时的效果^o^
ogvbox.DrawImage ogvbox.width-186, ogvbox.height-52, Logobox, 0.5  \'//水印图片的起始坐标,我这里ogvbox.width-186, ogvbox.height-52,表示图片在右下角,因为我的图片宽是186,高是52,所以这样写,你可以根据自己的图片进行调整。0.5是透明度,我这里是半透明,1表示不透明,你也可以试试看0.7或者0.8的效果。
ogvbox.Canvas.Bar 0, 0, ogvbox.Width, ogvbox.Height  \'//水印可用的范围。我这里表示左上角至右下角,即整张图片的任意为止都可加水印。
ogvbox.Save Server.MapPath(imagename)  \'//根据以上参数生成增加水印后的图片文件。
   End If
   ogvbox.Width = ImageWidth
   ogvbox.height = ImageHeight
   \'ogvbox.height = ogvbox.Originalheight*ImageWidth\\ogvbox.OriginalWidth
   ogvbox.Sharpen 1, 120
   ogvbox.Save Server.MapPath(tempFilename)  \'//生成增加水印后的图片的预览图片。
  End If
  Set Logobox=Nothing
 
<%
\'函数功能:远程图片自动保存到本地服务器,并利用aspjpeg为图片加上水印
\'(注意:请先在目录下创建images目录,用来保存临时图片)
\'程序落伍者:我是星星
\'加入落伍第二份原创程序,HOHO,今天一定要落伍类,5.6日注册,5.7日落伍,庆祝一下!
\'本程序需要在服务器上安装"aspjpeg组件"否则无法正常使用
\'也可以只取\'\'\'\'\'22222222\'\'\'\'\'\'\'以上的部分,这部分可以保存图片,第二部分是进行水印增加
\'使用方法,请保存为saveimg.asp
\'saveimg.asp?url=UploadFile/2005-6/2005615155335734.gif  即可以取下图片啦,HOHO. 其他需要加的功能,大家自己扩展好啦
\'如何获取其他后缀名的文件呢? 当然也可以啦
\'(jpg|gif|png|bmp)改成(mp3)明白吧? 就是取mp3后缀的文件名.以此类推. 嘻嘻
\'俺要落伍. 发了二份原创,一份是惊云下载系统偷天空时防止出现连接来自天空软件站的程序,有需要的在落伍里面搜索我的贴子
\'不要忘了使用时在目录下建images的保存目录哦
Server.ScriptTimeOut=99999
const savepath="images" \'图片保存路径
url=request("url")
 
function myreplace(str)
newstr=str
set objregEx = new RegExp
objregEx.IgnoreCase = true
objregEx.Global = true
objregEx.Pattern = " http://(.+?)\\.(jpg|gif|png|bmp)" \'定义文件后缀
set matches = objregEx.execute(str)
for each match in matches
newstr=replace(newstr,match.value,saveimg(match.value))
next
myreplace=newstr
end function
function saveimg(url)
temp=split(url,".")
\'以下是用时间与随机数重命名文件名
randomize
ranNum=int(90000*rnd)+10000
filename=year(now)&month(now)&day(now)&hour(now)&minute(now)&second(now)&ranNum&"."&temp(ubound(temp))
\'文件名重命名结束
set xmlhttp=server.createobject("Microsoft.XMLHTTP")
xmlhttp.open "get",url,false
xmlhttp.send
img=xmlhttp.ResponseBody
set xmlhttp=nothing
set objAdostream=server.createobject("ADODB.Stream")
objAdostream.Open()
objAdostream.type=1
objAdostream.Write(img)
objAdostream.SaveToFile(server.mappath(savepath&filename))
objAdostream.SetEOS
set objAdostream=nothing
\'\'\'\'\'\'\'222222222\'\'\'\'\'\'\'\'\'\'\'
saveimg=savepath&filename \'获取保存路径
Dim Jpeg
Set Jpeg = Server.CreateObject("Persits.Jpeg")
Jpeg.Open Server.MapPath(saveimg) \'打开保存图片的路径
\' 添加文字水印
Jpeg.Canvas.Font.Color = &HFF0000\' 红色
Jpeg.Canvas.Font.Family = "宋体"
Jpeg.Canvas.Font.Bold = True 
Jpeg.Canvas.Print Jpeg.OriginalWidth-200,Jpeg.OriginalHeight-50, " www.sina.com"  \'水印离左边的距离,离顶端的距离,这个是放在右下脚了
\'保存文件
Jpeg.Save Server.MapPath(saveimg) \'保存添加水印后的图片
\' 注销对象
Set Jpeg = Nothing
end function
%>

Set objImg = Server.CreateObject("Persits.Jpeg")
objImg.Interpolation = 2
\\\'影像加强 0-2
objImg.open xFilePath
response.write "<:::原始值:::>
AspJpeg版本=" & objImg.Version & "
宽=" & objImg.OriginalWidth & "像素
" & "高=" & objImg.OriginalHeight & "像素
"
response.write "品质=" & objImg.Quality & " (0-100)
" & "路径=" & objImg.Version & "
"
\\\'objImg.Width = objImg.OriginalWidth / 2
\\\'变更图片宽度(范例为50%)
\\\'objImg.Height = objImg.OriginalHeight / 2
\\\'变更图片高度(范例为50%)
\\\'objImg.Sharpen 2, 250
\\\'锐利处理
\\\'objImg.Crop 0,0,150,150
\\\'切割处理
\\\'objImg.FlipH
\\\'左右翻转
\\\'objImg.FlipV
\\\'上下翻转
\\\'objImg.RotateL
\\\'向左旋转90度
\\\'objImg.RotateR
\\\'向右旋转90度
\\\' 将图片秀上文字:------------------------
objImg.Canvas.Font.Color = &HFF0000
\\\'颜色
objImg.Canvas.Font.Family = "细明体"
\\\'字型
objImg.Canvas.Font.Bold = True
\\\'是否使用粗体
objImg.Canvas.Font.BkMode = False
\\\'是否使用字体背景色
objImg.Canvas.Font.BkColor = &H000000
\\\'字体背景色
objImg.Canvas.Font.Italic = False
\\\'是否使用斜体字
objImg.Canvas.Font.Rotation = 0
\\\'字体旋转角度
objImg.Canvas.Font.ShadowColor = &H000000
\\\'字影颜色
objImg.Canvas.Font.ShadowXOffset = 50
\\\'字影X坐标
objImg.Canvas.Font.ShadowYOffset = 150
\\\'字影Y坐标
objImg.Canvas.Font.Size = 14
\\\'字体大小
objImg.Canvas.Font.Underlined = True
\\\'是否加底限
objImg.Canvas.Circle 100,100,10
\\\'画圆圈
objImg.Canvas.Pen.Color = &H009900
\\\'画圆的圆内填满颜色
objImg.Canvas.Pen.Width = 1
\\\'画圆的圆周粗细值
objImg.Canvas.Ellipse 0,0,150,150
\\\'画椭圆
objImg.Canvas.Line 0,0,150,150
\\\'画线
\\\'objImg.Canvas.Arc = 100,50,0,200
\\\'---不清楚这个用法--
objImg.Canvas.Print 100, 100, "I am Odysseus" ,136
\\\'位置及文字---------------------------------

\\\' 编辑图片外框:----------------------------
objImg.Canvas.Pen.Color = &H000000
\\\'图片外框颜色
objImg.Canvas.Pen.Width = 1
\\\'图片外框宽度(像素)
objImg.Canvas.Brush.Solid = False
\\\'是否使用区域内填满
objImg.Canvas.Brush.Color = &HFF0000
\\\'区域内填满颜色
objImg.Canvas.Bar 5, 5, objImg.Width, objImg.Height
\\\'框线产生位置------------------------------
objImg.save xFileCopyToPath
response.write "<:::变化后:::>
宽=" & objImg.Width & "像素
" & "高=" & objImg.Height & "像素
"
Set objImg = Nothing