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") 保存 %>
     
三、安全码
安全玛的道理和加水印差不多,很多朋友问我要具体的代码技术,在这里我就写出来和大家分享,一般人我还不告诉他。呵呵。 <% 生成安全码的函数 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.fufuok.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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值