用asp實(shí)現(xiàn)把文件打包成Xml文件包,帶解包的ASP工具附下載
更新時(shí)間:2007年06月25日 00:00:00 作者:
把文件打包成Xml文件包,帶解包的ASP工具!
把網(wǎng)站源碼全部打包到Xml文件里面,生成 updata.xml 文件,把xml文件上傳到空間里面
然后通過 install.asp文件將文件全部釋放出來。
就和z-blog的 自動(dòng)安裝包一樣的功能呵呵。
代碼是落伍的一位兄弟寫的,不過代碼好像有錯(cuò)誤,這個(gè)是我參考他的 修改過了,可以正常運(yùn)行!~~
此代碼可以應(yīng)用到 asp程序的 自動(dòng)升級(jí)服務(wù)上面。具體怎么來實(shí)現(xiàn),歡迎探討!~~
就在下面回帖探討!~~~
不用設(shè)定打包目錄版,需要設(shè)定打包目錄版 這兩個(gè)版本的區(qū)別:
不用設(shè)定打包目錄版,直接放到你需要打包的目錄 執(zhí)行就可以了。
需要設(shè)定打包目錄版,必須指定需要打包的路徑(在程序里修改),不指定,不能進(jìn)行打包。
不用設(shè)定目錄-打包文件
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%>
<% Option Explicit %>
<% On Error Resume Next %>
<% Response.Charset="UTF-8" %>
<% Server.ScriptTimeout=99999999 %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>文件打包程序</title>
</head>
<body>
<%
Dim ZipPathDir,ZipPathFile,ZipFileExt
Dim startime,endtime
'在此更改要打包文件夾的路徑
ZipPathDir = Left(Request.ServerVariables("PATH_TRANSLATED"),InStrRev(Request.ServerVariables("PATH_TRANSLATED"),"\"))'
'生成的xml文件
ZipPathFile = "update.xml"
'不進(jìn)行打包的文件擴(kuò)展名
ZipFileExt = "db;bak"
if right(ZipPathDir,1)<>"\" then ZipPathDir=ZipPathDir&"\"
'開始打包
CreateXml(ZipPathFile)
'遍歷目錄內(nèi)的所有文件以及文件夾
sub LoadData(DirPath)
dim XmlDoc
dim fso 'fso對(duì)象
dim objFolder '文件夾對(duì)象
dim objSubFolders '子文件夾集合
dim objSubFolder '子文件夾對(duì)象
dim objFiles '文件集合
dim objFile '文件對(duì)象
dim objStream
dim pathname,TextStream,pp,Xfolder,Xfpath,Xfile,Xpath,Xstream
dim PathNameStr
response.Write("=========="&DirPath&"==========<br>")
set fso=server.CreateObject("scripting.filesystemobject")
set objFolder=fso.GetFolder(DirPath)'創(chuàng)建文件夾對(duì)象
Response.Write DirPath
Response.flush
Set XmlDoc = Server.CreateObject("Microsoft.XMLDOM")
XmlDoc.load(Server.MapPath(ZipPathFile))
XmlDoc.async=false
'寫入每個(gè)文件夾路徑
set Xfolder = XmlDoc.SelectSingleNode("http://root").AppendChild(XmlDoc.CreateElement("folder"))
Set Xfpath = Xfolder.AppendChild(XmlDoc.CreateElement("path"))
Xfpath.text = replace(DirPath,ZipPathDir,"")
set objFiles=objFolder.Files
for each objFile in objFiles
if lcase(DirPath & objFile.name) <> lcase(Request.ServerVariables("PATH_TRANSLATED")) and lcase(DirPath & objFile.name) <> lcase(DirPath & ZipPathFile) then
if ext(objFile.name) then
Response.Write "---<br/>"
PathNameStr = DirPath & "" & objFile.name
Response.Write PathNameStr & ""
Response.flush
'================================================
'寫入文件的路徑及文件內(nèi)容
set Xfile = XmlDoc.SelectSingleNode("http://root").AppendChild(XmlDoc.CreateElement("file"))
Set Xpath = Xfile.AppendChild(XmlDoc.CreateElement("path"))
Xpath.text = replace(PathNameStr,ZipPathDir,"")
'創(chuàng)建文件流讀入文件內(nèi)容,并寫入XML文件中
Set objStream = Server.CreateObject("ADODB.Stream")
objStream.Type = 1
objStream.Open()
objStream.LoadFromFile(PathNameStr)
objStream.position = 0
Set Xstream = Xfile.AppendChild(XmlDoc.CreateElement("stream"))
Xstream.SetAttribute "xmlns:dt","urn:schemas-microsoft-com:datatypes"
'文件內(nèi)容采用二制方式存放
Xstream.dataType = "bin.base64"
Xstream.nodeTypedValue = objStream.Read()
set objStream=nothing
set Xpath = nothing
set Xstream = nothing
set Xfile = nothing
'================================================
end if
end if
next
Response.Write "<p>"
XmlDoc.Save(Server.Mappath(ZipPathFile))
set Xfpath = nothing
set Xfolder = nothing
set XmlDoc = nothing
'創(chuàng)建的子文件夾對(duì)象
set objSubFolders=objFolder.Subfolders
'調(diào)用遞歸遍歷子文件夾
for each objSubFolder in objSubFolders
pathname = DirPath & objSubFolder.name & "\"
LoadData(pathname)
next
set objFolder=nothing
set objSubFolders=nothing
set fso=nothing
end sub
'創(chuàng)建一個(gè)空的XML文件,為寫入文件作準(zhǔn)備
sub CreateXml(FilePath)
'程序開始執(zhí)行時(shí)間
startime=timer()
dim XmlDoc,Root
Set XmlDoc = Server.CreateObject("Microsoft.XMLDOM")
XmlDoc.async = False
Set Root = XmlDoc.createProcessingInstruction("xml","version='1.0' encoding='UTF-8'")
XmlDoc.appendChild(Root)
XmlDoc.appendChild(XmlDoc.CreateElement("root"))
XmlDoc.Save(Server.MapPath(FilePath))
Set Root = Nothing
Set XmlDoc = Nothing
LoadData(ZipPathDir)
'程序結(jié)束時(shí)間
endtime=timer()
response.Write("頁面執(zhí)行時(shí)間:" & FormatNumber((endtime-startime),3) & "秒")
end sub
'判斷文件類型是否合法
function ext(filename)
ext = true
dim temp_ext,e
temp_ext = Split(ZipFileExt,";")
for e=0 to ubound(temp_ext)
if mid(filename,InstrRev(filename,".")+1)=temp_ext(e) then ext=false
next
end function
%>
</body>
</html>
解壓asp文件
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%>
<% Option Explicit %>
<% On Error Resume Next %>
<% Response.Charset="UTF-8" %>
<% Server.ScriptTimeout=99999999 %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>文件解包程序</title>
</head>
<body>
<%
Dim strLocalPath
'得到當(dāng)前文件夾的物理路徑
strLocalPath=Left(Request.ServerVariables("PATH_TRANSLATED"),InStrRev(Request.ServerVariables("PATH_TRANSLATED"),"\"))
Dim objXmlFile
Dim objNodeList
Dim objFSO
Dim objStream
Dim i,j
Set objXmlFile = Server.CreateObject("Microsoft.XMLDOM")
objXmlFile.load(Server.MapPath("update.xml"))
If objXmlFile.readyState=4 Then
If objXmlFile.parseError.errorCode = 0 Then
Set objNodeList = objXmlFile.documentElement.selectNodes("http://folder/path")
Set objFSO = CreateObject("Scripting.FileSystemObject")
j=objNodeList.length-1
For i=0 To j
If objFSO.FolderExists(strLocalPath & objNodeList(i).text)=False Then
objFSO.CreateFolder(strLocalPath & objNodeList(i).text)
End If
Response.Write "創(chuàng)建目錄" & objNodeList(i).text & "<br/>"
Response.Flush
Next
Set objFSO = nothing
Set objNodeList = nothing
Set objNodeList = objXmlFile.documentElement.selectNodes("http://file/path")
j=objNodeList.length-1
For i=0 To j
Set objStream = CreateObject("ADODB.Stream")
With objStream
.Type = 1
.Open
.Write objNodeList(i).nextSibling.nodeTypedvalue
.SaveToFile strLocalPath & objNodeList(i).text,2
Response.Write "釋放文件" & objNodeList(i).text & "<br/>"
Response.Flush
.Close
End With
Set objStream = Nothing
Next
Set objNodeList = nothing
End If
End If
Set objXmlFile = Nothing
response.write "文件解包完畢"
%>
</body>
</html>
打包文件下載
把網(wǎng)站源碼全部打包到Xml文件里面,生成 updata.xml 文件,把xml文件上傳到空間里面
然后通過 install.asp文件將文件全部釋放出來。
就和z-blog的 自動(dòng)安裝包一樣的功能呵呵。
代碼是落伍的一位兄弟寫的,不過代碼好像有錯(cuò)誤,這個(gè)是我參考他的 修改過了,可以正常運(yùn)行!~~
此代碼可以應(yīng)用到 asp程序的 自動(dòng)升級(jí)服務(wù)上面。具體怎么來實(shí)現(xiàn),歡迎探討!~~
就在下面回帖探討!~~~
不用設(shè)定打包目錄版,需要設(shè)定打包目錄版 這兩個(gè)版本的區(qū)別:
不用設(shè)定打包目錄版,直接放到你需要打包的目錄 執(zhí)行就可以了。
需要設(shè)定打包目錄版,必須指定需要打包的路徑(在程序里修改),不指定,不能進(jìn)行打包。
不用設(shè)定目錄-打包文件
復(fù)制代碼 代碼如下:
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%>
<% Option Explicit %>
<% On Error Resume Next %>
<% Response.Charset="UTF-8" %>
<% Server.ScriptTimeout=99999999 %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>文件打包程序</title>
</head>
<body>
<%
Dim ZipPathDir,ZipPathFile,ZipFileExt
Dim startime,endtime
'在此更改要打包文件夾的路徑
ZipPathDir = Left(Request.ServerVariables("PATH_TRANSLATED"),InStrRev(Request.ServerVariables("PATH_TRANSLATED"),"\"))'
'生成的xml文件
ZipPathFile = "update.xml"
'不進(jìn)行打包的文件擴(kuò)展名
ZipFileExt = "db;bak"
if right(ZipPathDir,1)<>"\" then ZipPathDir=ZipPathDir&"\"
'開始打包
CreateXml(ZipPathFile)
'遍歷目錄內(nèi)的所有文件以及文件夾
sub LoadData(DirPath)
dim XmlDoc
dim fso 'fso對(duì)象
dim objFolder '文件夾對(duì)象
dim objSubFolders '子文件夾集合
dim objSubFolder '子文件夾對(duì)象
dim objFiles '文件集合
dim objFile '文件對(duì)象
dim objStream
dim pathname,TextStream,pp,Xfolder,Xfpath,Xfile,Xpath,Xstream
dim PathNameStr
response.Write("=========="&DirPath&"==========<br>")
set fso=server.CreateObject("scripting.filesystemobject")
set objFolder=fso.GetFolder(DirPath)'創(chuàng)建文件夾對(duì)象
Response.Write DirPath
Response.flush
Set XmlDoc = Server.CreateObject("Microsoft.XMLDOM")
XmlDoc.load(Server.MapPath(ZipPathFile))
XmlDoc.async=false
'寫入每個(gè)文件夾路徑
set Xfolder = XmlDoc.SelectSingleNode("http://root").AppendChild(XmlDoc.CreateElement("folder"))
Set Xfpath = Xfolder.AppendChild(XmlDoc.CreateElement("path"))
Xfpath.text = replace(DirPath,ZipPathDir,"")
set objFiles=objFolder.Files
for each objFile in objFiles
if lcase(DirPath & objFile.name) <> lcase(Request.ServerVariables("PATH_TRANSLATED")) and lcase(DirPath & objFile.name) <> lcase(DirPath & ZipPathFile) then
if ext(objFile.name) then
Response.Write "---<br/>"
PathNameStr = DirPath & "" & objFile.name
Response.Write PathNameStr & ""
Response.flush
'================================================
'寫入文件的路徑及文件內(nèi)容
set Xfile = XmlDoc.SelectSingleNode("http://root").AppendChild(XmlDoc.CreateElement("file"))
Set Xpath = Xfile.AppendChild(XmlDoc.CreateElement("path"))
Xpath.text = replace(PathNameStr,ZipPathDir,"")
'創(chuàng)建文件流讀入文件內(nèi)容,并寫入XML文件中
Set objStream = Server.CreateObject("ADODB.Stream")
objStream.Type = 1
objStream.Open()
objStream.LoadFromFile(PathNameStr)
objStream.position = 0
Set Xstream = Xfile.AppendChild(XmlDoc.CreateElement("stream"))
Xstream.SetAttribute "xmlns:dt","urn:schemas-microsoft-com:datatypes"
'文件內(nèi)容采用二制方式存放
Xstream.dataType = "bin.base64"
Xstream.nodeTypedValue = objStream.Read()
set objStream=nothing
set Xpath = nothing
set Xstream = nothing
set Xfile = nothing
'================================================
end if
end if
next
Response.Write "<p>"
XmlDoc.Save(Server.Mappath(ZipPathFile))
set Xfpath = nothing
set Xfolder = nothing
set XmlDoc = nothing
'創(chuàng)建的子文件夾對(duì)象
set objSubFolders=objFolder.Subfolders
'調(diào)用遞歸遍歷子文件夾
for each objSubFolder in objSubFolders
pathname = DirPath & objSubFolder.name & "\"
LoadData(pathname)
next
set objFolder=nothing
set objSubFolders=nothing
set fso=nothing
end sub
'創(chuàng)建一個(gè)空的XML文件,為寫入文件作準(zhǔn)備
sub CreateXml(FilePath)
'程序開始執(zhí)行時(shí)間
startime=timer()
dim XmlDoc,Root
Set XmlDoc = Server.CreateObject("Microsoft.XMLDOM")
XmlDoc.async = False
Set Root = XmlDoc.createProcessingInstruction("xml","version='1.0' encoding='UTF-8'")
XmlDoc.appendChild(Root)
XmlDoc.appendChild(XmlDoc.CreateElement("root"))
XmlDoc.Save(Server.MapPath(FilePath))
Set Root = Nothing
Set XmlDoc = Nothing
LoadData(ZipPathDir)
'程序結(jié)束時(shí)間
endtime=timer()
response.Write("頁面執(zhí)行時(shí)間:" & FormatNumber((endtime-startime),3) & "秒")
end sub
'判斷文件類型是否合法
function ext(filename)
ext = true
dim temp_ext,e
temp_ext = Split(ZipFileExt,";")
for e=0 to ubound(temp_ext)
if mid(filename,InstrRev(filename,".")+1)=temp_ext(e) then ext=false
next
end function
%>
</body>
</html>
解壓asp文件
復(fù)制代碼 代碼如下:
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%>
<% Option Explicit %>
<% On Error Resume Next %>
<% Response.Charset="UTF-8" %>
<% Server.ScriptTimeout=99999999 %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>文件解包程序</title>
</head>
<body>
<%
Dim strLocalPath
'得到當(dāng)前文件夾的物理路徑
strLocalPath=Left(Request.ServerVariables("PATH_TRANSLATED"),InStrRev(Request.ServerVariables("PATH_TRANSLATED"),"\"))
Dim objXmlFile
Dim objNodeList
Dim objFSO
Dim objStream
Dim i,j
Set objXmlFile = Server.CreateObject("Microsoft.XMLDOM")
objXmlFile.load(Server.MapPath("update.xml"))
If objXmlFile.readyState=4 Then
If objXmlFile.parseError.errorCode = 0 Then
Set objNodeList = objXmlFile.documentElement.selectNodes("http://folder/path")
Set objFSO = CreateObject("Scripting.FileSystemObject")
j=objNodeList.length-1
For i=0 To j
If objFSO.FolderExists(strLocalPath & objNodeList(i).text)=False Then
objFSO.CreateFolder(strLocalPath & objNodeList(i).text)
End If
Response.Write "創(chuàng)建目錄" & objNodeList(i).text & "<br/>"
Response.Flush
Next
Set objFSO = nothing
Set objNodeList = nothing
Set objNodeList = objXmlFile.documentElement.selectNodes("http://file/path")
j=objNodeList.length-1
For i=0 To j
Set objStream = CreateObject("ADODB.Stream")
With objStream
.Type = 1
.Open
.Write objNodeList(i).nextSibling.nodeTypedvalue
.SaveToFile strLocalPath & objNodeList(i).text,2
Response.Write "釋放文件" & objNodeList(i).text & "<br/>"
Response.Flush
.Close
End With
Set objStream = Nothing
Next
Set objNodeList = nothing
End If
End If
Set objXmlFile = Nothing
response.write "文件解包完畢"
%>
</body>
</html>
打包文件下載
相關(guān)文章
做了CDN加速的ASP網(wǎng)站獲取用戶真實(shí)IP程序
寫了下asp取真實(shí)IP的代碼,搭環(huán)境測(cè)試無代理、一級(jí)或多級(jí)代理的情況,可以正常獲取2010-11-11TSYS中生成靜態(tài)頁時(shí)溢出: ''CInt''
TSYS中生成靜態(tài)頁時(shí)溢出: ''CInt''...2007-01-01ASP開發(fā)中可能遇到的錯(cuò)誤信息中文說明大全(整理收集)
ASP開發(fā)中可能遇到的錯(cuò)誤信息中文說明大全(整理收集)...2007-03-03asp中提示至少一個(gè)參數(shù)沒有被指定值 解決方法
在寫SQL語句的時(shí)候,我們經(jīng)常會(huì)調(diào)用一些參數(shù),很可能這些參數(shù)中有一個(gè)沒有被賦值2012-10-10TSYS一個(gè)新聞多種特性時(shí)如何進(jìn)行前臺(tái)更新?
TSYS一個(gè)新聞多種特性時(shí)如何進(jìn)行前臺(tái)更新?...2007-01-01ASP基礎(chǔ)入門第二篇(ASP基礎(chǔ)知識(shí))
這篇文章是ASP基礎(chǔ)入門第二篇,第一篇展示了ASP動(dòng)態(tài)網(wǎng)站設(shè)計(jì)的一些最基本的方法,相信通過實(shí)踐各位對(duì) ASP 已經(jīng)有了最基本的了解,本文將進(jìn)一步介紹ASP動(dòng)態(tài)網(wǎng)站的一些基本技巧,需要的朋友可以參考下2015-10-10