首页 > 开发 > Asp > 正文

用ASP实现在线压缩与解压缩功能代码

2020-06-20 14:04:02
字体:
来源:转载
供稿:网友

先上一个完整代码

<!--Name -ASP在线解压,压缩工具 copyright -错新站长站(www.Cuoxin.com)--><%@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=99999Dim winrar,cmddirWinrar="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 thenresponse.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><%ErrInfoend ifelselogin()end ifSub 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 SubFunction ReportFileStatus(filespec) Dim fso Set fso = CreateObject("Scripting.FileSystemObject") ReportFileStatus=false If (fso.FileExists(filespec)) Then ReportFileStatus = true Set fso =nothingEnd FunctionFunction ReportFolderStatus(fldr) Dim fso Set fso = CreateObject("Scripting.FileSystemObject") ReportFolderStatus=false If (fso.FolderExists(fldr)) Then ReportFolderStatus = true Set fso =nothingEnd FunctionSub 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="//www.Cuoxin.com">错新站长站</a></td></tr></table></body>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表