微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ASP在线自动解压缩实现函数

编程之家改版加入了JS代码模块,JS代码模块需要做在线演示与下载,就用到了自动解压功能上传上去压缩文件自动把压缩文件解压,编程之家下面跟大家分享实现方法

ASP在线自动解压缩实现函数

<html>

<head>

<Meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>ASP在线解压缩-编程之家</title>

</head>

<body>

<TABLE

 border=0 width=80% align=center cellspacing=1 cellpadding=3 

FONT-FAMILY: Verdana;font-size:14px;BORDER: #000000 1px 

solid;background-color:#f7f7f7">

<tr>

</tr>

<tr>

<td bgcolor="#33CCFF">

<%

Server.ScriptTimeout=99999

Dim winrar,cmddir

Winrar="C:Program FilesWinRARWinrar.exe" '压缩文件(Winrar)的地址

cmddir="%windir%system32cmd.exe" 'cmd.exe(命令提示符)的地址

 

if request.Form("user")=qdxw and request.Form("pwd")=qdxw 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" 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" 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" 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" BORDER: #d9d9d9 1px solid;background-color:#f7f7f7">

  <p>--------------------------------------<strong>登陆系

统</strong>---------------------------------------<br>

    <br>

用户名

<input name="user" value="test">

  </p>

密 码:

    <input name="pwd" type="password" id="pwd"> 

    <br>

  <br>

  <input name="submit" type="submit" value=" 登陆 ">

</FORM>

<%End sub%>

</td>

</tr>

</table>

</body>

</html>

ASP自动加压缩函数的使用方法

1、复制所有代码保存为一个asp文件

2、然后IIS在线预览这个ASP文件即可。用户名密码都是:qdxw

3、大家可以参考这个实现方法进行自我发挥修改

4、windows 2003的服务器不支持WScript.Shell,解决方法可以参考:IIS下创建WScript.Shell失败的解决方法

5、windows2008的服务器支持哦。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐