用ASP實現線上壓縮與解壓縮功能程式碼

發表於2019-11-02

您還在為空間的FTP不穩定而煩惱嗎?現在您只用上傳您的RAR壓縮包,即可!ASP線上解壓/壓縮工具只要幾秒的時間,解決了網速慢,FTP丟失資料的一大難題

先上一個完整程式碼

<!--
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="//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下執行透過。

相關文章