用ASP实现在线压缩与解压缩功能代码
先上一个完整代码
<!-- name -asp在线解压,压缩工具 copyright -(www.jb51.net) --> <%@language="vbscript" codepage="936"%> <title>欢迎使用asp在线解压,压缩工具</title> <body> <table border=0 width=80% align=center cellspacing=1 cellpadding=3 style="font-family: verdana;font-size:14px;border: #000000 1px solid;background-color:#f7f7f7"> <tr> <th width="100%" height="24" bgcolor="#33ccff"> </th> </tr> <tr> <td bgcolor="#33ccff"> <% server.scripttimeout=99999 dim winrar,cmddir winrar="c:\program files\winrar\winrar.exe" '压缩文件(winrar)的地址 cmddir="%windir%\system32\cmd.exe" 'cmd.exe(命令提示符)的地址 user="csisp" '本程序的用户名 pwd="csisp" '本程序的登陆、压缩、解压缩密码,请大家务必修改(至少8位以上的组合密码才够安全!) if request.form("user")=user and request.form("pwd")=pwd then response.write "本文件夹路径:"&server.mappath(".")&"<br>" from=request.form("from") where=request.form("where") if from<>"" and where<>"" then dim a,b,shell,runing,runcode,cmd if instr(where,":")=0 then a=server.mappath(""&where&"") else a=where if instr(from,":")=0 then b=server.mappath(""&from&"") else b=from 'response.write b if right(b,1)<>"\" and left(right(b,4),1)<>"." then b=b&".rar" on error resume next set shell = server.createobject("wscript.shell") if request.querystring("action")=1 then '解压缩 if not reportfilestatus(b)then response.write("没有找到 "&b&"可能不存在!"):response.end() runing= cmddir&" /c """&winrar&""" x -ibck -t -y -o+ -p"&pwd&" " '设置运行解压缩的命令。 cmd=runing&b&" "&a&"\" elseif request.querystring("action")=0 then '压缩文件 if (not reportfilestatus(a)) and (not reportfolderstatus(a)) then response.write("没有找到 "&a&"可能不存在!"):response.end() cmd= cmddir&" /c del /f /q "&b runcode = shell.run(cmd,1,true) runing= cmddir&" /c """&winrar&""" a -ibck -y -ep -o+ -p"&pwd&" " '压缩。 cmd=runing&b&" "&a else '删除文件 cmd= cmddir&" /c del /f /q "&b end if runcode = shell.run(cmd,1,true) runing = shell.run(cmddir&" /c taskkill /im winrar.exe",1,false) runing = shell.run(cmddir&" /c exit",1,false) set shell=nothing errinfo %> <%else%> <form name="frm" method="post" action="?action=1" style="border: #d9d9d9 1px solid;background-color:#f7f7f7"> --------------------------------------<strong>解压缩文件</strong>--------------------------------------- <br> <br> 请输入rar压缩文件地址: <input name="from" value="1.rar" size="50"><br> 解压到:<input name="where" value="." size="50"> 文件夹请使用绝对路径且在最后加 "\" <br> <br> <input name="submit" type="submit" value=" 解 压 "><input type="hidden" name="user" value="<%=request.form("user")%>"> <input type="hidden" name="pwd" value="<%=request.form("pwd")%>"> </form> <form name="frm" method="post" action="?action=0" style="border: #d9d9d9 1px solid;background-color:#f7f7f7"> --------------------------------------<strong>压缩文件</strong>---------------------------------------<br> <br> 请在此输入您要压缩文件地址: <input name="where" value="./data/dvbbs7#.mdb" size="50"> 您也可以输入文件夹<br> <br> 存放路径及新文件名:<input name="from" value="../data/1.rar" size="50"> 自动覆盖同名文件<br> <br> <input name="submit" type="submit" value=" 压 缩 "><input type="hidden" name="user" value="<%=request.form("user")%>"> <input type="hidden" name="pwd" value="<%=request.form("pwd")%>"></form> <% errinfo end if else login() end if sub errinfo if not isempty(runcode) and runcode=0 then response.write("操作成功执行,您提交的操作如下:<br>"& cmd) elseif not isempty(runcode) then response.write("操作执行失败!可能您的权限不够或者该程序无法在dos(命令提示符)下运行,您提交的操作如下:<br>" & cmd) else end if if err then response.write "<br>"&err.description err.clear end if %> <form name="frm" method="post" action="?action=2" style="border: #d9d9d9 1px solid;background-color:#f7f7f7"> --------------------------------------<strong>删除文件</strong>---------------------------------------<br> <br> 请输入要删除文件地址:<input name="from" size="50" value=<%=from%>> 文件夹请使用绝对路径且在最后加“\” <br> <input type="hidden" name="where" value=<%if where<>"" then response.write where else response.write "."%>> <br> <input name="submit" type="submit" value=" 删 除 "> <input type="hidden" name="user" value="<%=request.form("user")%>"> <input type="hidden" name="pwd" value="<%=request.form("pwd")%>"> </form> <br> <% end sub function reportfilestatus(filespec) dim fso set fso = createobject("scripting.filesystemobject") reportfilestatus=false if (fso.fileexists(filespec)) then reportfilestatus = true set fso =nothing end function function reportfolderstatus(fldr) dim fso set fso = createobject("scripting.filesystemobject") reportfolderstatus=false if (fso.folderexists(fldr)) then reportfolderstatus = true set fso =nothing end function sub login() %> <form name="frm" method="post" action="?action=2" style="border: #d9d9d9 1px solid;background-color:#f7f7f7"> <p>--------------------------------------<strong>登陆系统</strong>---------------------------------------<br> <br> 用户名: <input name="user" value="csisp"> </p> 密 码: <input name="pwd" type="password" id="pwd"> <br> <br> <input name="submit" type="submit" value=" 登陆 "> </form> <%end sub%> </td> </tr> <tr> <td height="22" align="center" bgcolor="#ffffff"> copyright ©2008 <a href="https://www.jb51.net"></a></td> </tr> </table> </body>
使用方法:
1.直接上传到服务器上(虚拟主机)的任何目录下(最好是根目录)
2.用浏览器访问winrar.asp文件地址
3.输入帐号和密码 (默认帐号: csisp 默认密码: csisp)
4.输入winrar文件的地址(*.rar) 确认后即可解压
5.输入您想压缩文件的地址,确认后即可压缩!
特别提示: 文件地址是本winrar系统的相对地址!
使用本程序的服务器必须连安装了winrar (一般的服务器都安装)
本程序的默认程序地址适合99%以上的服务器(虚拟主机)
如果地址不对,可以自己修改,地址为您安装winrar的地址(虚拟主机使用者请联系您虚拟主机的客服)
下面一些细节说明与补充
一、问题的提出
随着互连网的发展,网站的数量以惊人的数字增加。网站的作用除了给广大网友们提供信息资讯服务外,还应该成为网友们上传与下载文件的场所。在上传与下载文件的过程中,传输时间是关键,这就要求有较快的传输速度。在传输速度固定不变或是上下变动不大的情况下,尽量减小传输文件的体积,是一个可行的办法:上传文件的时候,先将要上传的文件用winrar压缩,上传成功后在网站内通过程序实现解压缩;下载文件的时候,先将要下载的文件在网站内通过程序实现压缩然后再下载。本文就针对该问题的解决进行探讨。
二、方法与说明
首先要上传一个winrar的解压程序,就是winrar自己的解压程序,只需要它的核心程序rar.exe这个文件就可以了,在winrar的安装目录里可以找到。然后要上传一个执行rar.exe的程序 cmd.exe 这个是windows操作系统里的程序,在系统盘winnt/system32文件夹中可以找到。上传完这两个文件后,就需要编写一些程序代码来实现压缩与解压缩。
不妨将实现压缩功能的文件取名为zip.asp,实现解压缩功能的文件取名为unzip.asp。
程序代码中包含了winrar这个应用程序的命令行语法,下面简单介绍一下:
winrar <命令> -<开关1> -<开关n> <压缩文件> <文件...> <@列表文件...> <解压路径/>
命令 要 winrar 运行的字符组合代表功能。
开关 切换操作指定类型,压缩强度,压缩文件类型,等等的定义。
压缩文件 要处理的压缩文件名。
文件 要处理的文件名。
列表文件 列表文件是包含要处理文件名称的纯文本。文件名应该在第一卷启动。可以在列表文件中使用//字符后添加注释。例如,你可以包含两列字符串创建 backup.lst:c:/work/doc/*.txt //备份文本文档 c:/work/image/*.bmp //备份图片c:/work/misc并接着运行: winrar a backup @backup.lst你可以在命令行中同时指定普通的文件名和列表文件名。
解压路径 只与命令 e 和 x ,搭配使用。指出解压文件添加的位置。如果文件夹不存在时,会自动创建。
字母命令列表:
a 添加文件到压缩文件 | c 添加压缩文件注释 |
d 从压缩文件删除文件 | e 从压缩文件解压压缩,忽略路径 |
f 刷新压缩文件中的文件 | i 在压缩文件中查找字符串 |
k 锁定压缩文件 | m 移动文件和文件夹到压缩文件 |
r 修复受损的压缩文件 | rc 重建丢失的卷 |
rn 重命名压缩文件 | rr[n] 添加数据恢复记录 |
rv[n] 创建恢复卷 | s[name] 转换压缩文件成为自解压文件类型 |
s- 删除自解压模块 | t 测试压缩文件 |
u 从压缩文件中更新文件 | x 以完整路径名称从压缩文件解压压缩 |
其实程序代码中的关键之处就是用server.createobject("wscript.shell")来执行cmd.exe,cmd.exe运行rar.exe通过winrar的命令来执行解压缩文件与压缩文件的。
三、程序清单
zip.asp程序清单:
<% 'main文件夹中包含cmd.exe rar.exe 例如:要压缩的文件(*.mdb) '压缩后的存放目录为main/data.rar on error resume next unzip_path=server.mappath("main")&"/" set wshshell = server.createobject("wscript.shell") issuccess = wshshell.run ("winrar a "&unzip_path&"data "&unzip_path&"*.mdb",1, false) 'winrar <命令> -<开关1> -<开关n> <压缩文件> <文件...> <@列表文件...> <解压路径/> '命令: a - 添加到压缩文件中 if issuccess = 0 then response.write " 命令成功执行!" else response.write " 命令执行失败!权限不够或者该程序无法运行" end if if err.number <> 0 then response.write "<p>错误号码:" & err.number response.write "<p>原因:" & err.description response.write "<p>错误来源:" & err.source response.write end if %>
unzip.asp程序清单:
<% 'main文件夹中包含cmd.exe rar.exe 要解压缩的文件(*.rar) '解压缩后的存放目录为main on error resume next unzip_path=server.mappath("main")&"/" set wshshell = server.createobject("wscript.shell") issuccess = wshshell.run ("winrar x -r -o+ "&unzip_path&"*.rar "&unzip_path&"",1, false) 'winrar <命令> -<开关1> -<开关n> <压缩文件> <文件...> <@列表文件...> <解压路径/> '命令: x - 从压缩文件中全路径解压文件 '开关: -r - 连同子文件夹 '开关: -o+ - 覆盖已经存在的文件 '开关: -o- - 不覆盖已经存在的文件 if issuccess = 0 then response.write " 命令成功执行!" else response.write " 命令执行失败!权限不够或者该程序无法运行" end if if err.number <> 0 then response.write "<p>错误号码:" & err.number response.write "<p>原因:" & err.description response.write "<p>错误来源:" & err.source response.write end if %>
四、 结论
本文通过使用rar.exe和 cmd.exe这两个文件,在asp编程中实现在线压缩与解压缩网站中的文件的功能。实现方法简单,程序代码少,可供实用编程时借鉴使用。尤其是在拥有自己的服务器的情况下极其实用和方便。以上程序在windows2000sever及iis5.0下运行通过。