• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    用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=Runingb" "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=Runingb" "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">nbsp;Copyright copy;2008nbsp; 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下运行通过。

    您可能感兴趣的文章:
    • 用ASP.Net实现文件的在线压缩和解压缩
    • ASP 连接Access数据库的登陆系统
    • asp连接access、sql数据库代码及数据库操作代码
    • ASP连接Access数据库的几种方法
    • access数据库的一些少用操作,ASP,创建数据库文件,创建表,创建字段,ADOX
    • 深入浅析ASP在线压缩access数据库的方法
    上一篇:SharePoint Server 2019新特性介绍
    下一篇:ASP是使用正则提取内容里所有图片路径SRC的实现代码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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