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

简介:

自己整理出来的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
分类:  Javascript

本文转自快乐就好博客园博客,原文链接:http://www.cnblogs.com/happyday56/archive/2007/11/24/971311.html,如需转载请自行联系原作者
相关文章
|
前端开发 JavaScript
富文本编辑器wangEdiotr,编辑内容后,重新打开报错Uncaught (in promise) Error: Cannot find a descendant at path
富文本编辑器wangEdiotr,编辑内容后,重新打开报错Uncaught (in promise) Error: Cannot find a descendant at path
2406 1
解决layUI请求上传接口出现异常的解决方案
解决layUI请求上传接口出现异常的解决方案
575 0
|
缓存 前端开发 JavaScript
前端开发的必修课:如何让你的网页在弱网环境下依然流畅运行?
【10月更文挑战第30天】随着移动互联网的普及,弱网环境下的网页性能优化变得尤为重要。本文详细介绍了如何通过了解网络状况、优化资源加载、减少HTTP请求、调整弱网参数和代码优化等方法,提升网页在弱网环境下的加载速度和流畅性,从而改善用户体验。
652 4
|
数据采集 人工智能 自然语言处理
AI Agent 金融助理0-1 Tutorial 利用Python实时查询股票API的FinanceAgent框架构建股票(美股/A股/港股) AI Finance Agent
金融领域Finance AI Agents方面的工作,发现很多行业需求和用户输入的 query都是和查询股价/行情/指数/财报汇总/金融理财建议相关。如果需要准确的 金融实时数据就不能只依赖LLM 来生成了。常规的方案包括 RAG (包括调用API )再把对应数据和prompt 一起拼接送给大模型来做文本生成。稳定的一些商业机构的金融数据API基本都是收费的,如果是以科研和demo性质有一些开放爬虫API可以使用。这里主要介绍一下 FinanceAgent,github地址 https://github.com/AI-Hub-Admin/FinanceAgent
|
Linux 数据处理
Linux命令reset详解
`reset`命令在Linux中用于修复终端显示异常,它是`tset`的软链接。通过重置显示属性和参数,恢复终端正常状态。特点包括自动检测终端类型、多参数支持及恢复显示设置。常用参数有 `-e`, `-i`, `-k` 用于设置控制字符,`-V` 显示ncurses版本。在终端出现问题时,简单运行`reset`即可重置,定期使用可维护终端整洁。记得确保已安装ncurses库。
|
前端开发 JavaScript Java
杨老师教你学会使用富文本编辑器KindEditor之添加页面设计
杨老师教你学会使用富文本编辑器KindEditor之添加页面设计
359 0
|
前端开发 JavaScript
如何处理用户的拖拽排序操作
这个示例展示了如何使用JavaScript处理HTML列表的拖拽排序。通过监听`dragstart`、`dragend`、`dragenter`、`dragleave`、`dragover`和`drop`事件,实现拖拽元素时的视觉反馈和元素位置交换。当用户拖放列表项时,相关事件触发,更新列表顺序,提供直观的交互体验。
|
移动开发 前端开发 JavaScript
使用JavaScript实现一个复杂功能:自定义拖拽排序列表
使用JavaScript实现一个复杂功能:自定义拖拽排序列表
基于sortablejs实现拖拽element-ui el-table表格行进行排序
基于sortablejs实现拖拽element-ui el-table表格行进行排序