网站打包方法之一:所有文件转为XML文件(ASP)

2009年09月29日   编程开发   0条评论   3558人围观过  
接上一篇文章,那里讨论了数据库还原的问题,我这里继续讲剩下的部分写完整。

我这里再提一下事件起因:我的网站还有一个月要到期,可恶的空“奸”商将空间的FTP功能关闭了,目的就是让那些麻痹大意,不注意实时备份的站长中招的,这样一来,你就没法离开这家空间商去换另一家空间,因为你没法获得自己的web文件,要么你继续续费,FTP功能就打开了,但是这样就失去换空间的意义,要么就的多花一年空间费的冤枉钱。

经过绞尽脑汁的想,终于找到了转移的方法。前提,上一篇已经提过了,如果你是使用mssql或者MySQL等数据库的,你还必须得想法子弄到自己的数据库,不过一般情况备份的数据库文件和web文件不是一个通道下载,基本上是另外新建一个临时的,星外面板就这样。我们这里就只研究怎么样在FTP功能关闭的情况下,利用http方式获得自己的网站的web文件。

还有一个前提,而且是很关键的,如果你整站是HTML页面,每一个后台,说具体一点,没有在线修改你自己网页代码功能的,并且是动态页面,那么你也束手无策的。

当然一般情况下,现在的站长都是使用了各种的系统,例如CMS或者博客系统等,这些系统后台都能编辑修改自己系统的页面,就是利用这个关键,我才想到了如下的方法。

我的站上刚好装有一个Zblog,很久没用,还好没删掉,利用该blog后台的文件管理功能,我们使用了一组代码,将指定目录下的所有文件打包成二进制的流文件,生成如XML文件后,再使用工具下载回来本地,使用另一组代码,将打包后的文件还原为原文件即可。

我们先来看打包代码,将该代码复制,然后进到zblog后台,利用文件管理功能,查到了你网站的web目录在该服务器上的绝对路径,将该代码中的路径修改为你查到的,要想打包的目录,即下面代码中的红色部分,粘贴到任意一个动态页面里,在zblog中我选择了WAP.asp文件,然后保存,利用浏览器访问该页面,则打包代码得到执行,你将在浏览器中看到打包的过程,最后得到一个时间,即表示打包完成,耗时这么多时间。这里要注意,我自己试验的时候,打包成XML文件,结果下载不了,可能服务器限制了改文件的下载,同理,你打包成其他文件,一般的虚拟主机都有限制,经过试验,打包成txt文件最为方便,即修改下面代码中蓝色部分。打包后将在wap.asp所在目录下生成一个xxx.txt文件,下载即可。

打包代码:

[sourcecode language="vb"]
<%@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
Dim startime,endtime

'在此更改要打包文件夹的路径
ZipPathDir = "D:\Program Files\智能手机工作室\"
'ZipPathDir=server.mappath(""&ZipPathDir&"")
ZipPathFile = "update.txt"
if right(ZipPathDir,1)<>"\" then ZipPathDir=ZipPathDir&"\"

'开始打包
CreateXml(ZipPathFile)
'遍历目录内的所有文件以及文件夹

sub LoadData(DirPath)
dim XmlDoc
dim fso 'fso对象
dim objFolder '文件夹对象
dim objSubFolders '子文件夹集合
dim objSubFolder '子文件夹对象
dim objFiles '文件集合
dim objFile '文件对象
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)'创建文件夹对象
Response.Write DirPath
Response.flush
Set XmlDoc = Server.CreateObject("Microsoft.XMLDOM")
XmlDoc.load Server.MapPath(ZipPathFile)
XmlDoc.async=False

'写入每个文件夹路径
set Xfolder = XmlDoc.SelectSingleNode("//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")) then
Response.Write "---
"
PathNameStr = DirPath & "" & objFile.name
Response.Write PathNameStr & ""
Response.flush

'================================================

'写入文件的路径及文件内容
set Xfile = XmlDoc.SelectSingleNode("//root").AppendChild(XmlDoc.CreateElement("file"))
Set Xpath = Xfile.AppendChild(XmlDoc.CreateElement("path"))
Xpath.text = replace(PathNameStr,ZipPathDir,"")'创建文件流读入文件内容,并写入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"
'文件内容采用二制方式存放
Xstream.dataType = "bin.base64"
Xstream.nodeTypedValue = objStream.Read()
set objStream=nothing
set Xpath = nothing
set Xstream = nothing
set Xfile = Nothing

'================================================
end if
Next

Response.Write "<p>"
XmlDoc.Save(Server.Mappath(ZipPathFile))
set Xfpath = nothing
set Xfolder = nothing
set XmlDoc = Nothing

'创建的子文件夹对象
set objSubFolders=objFolder.Subfolders'调用递归遍历子文件夹
for each objSubFolder in objSubFolders
pathname = DirPath & objSubFolder.name & "\"
LoadData(pathname)
next
set objFolder=nothing
set objSubFolders=nothing
set fso=nothing
end Sub

'创建一个空的XML文件,为写入文件作准备
sub CreateXml(FilePath)'程序开始执行时间
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)
'程序结束时间
endtime=timer()
response.Write("页面执行时间:" & FormatNumber((endtime-startime),3) & "秒")
End sub%>
</body>
</html>
[/sourcecode]

下载回来后,我们将进行解包以还原为原来的文件类型,使用下面的代码解包,注意蓝色部分的文件名必须为你下载回来的文件名,同时解包后生成的所有文件将存放在这个解包页面的目录中。

解包代码:

[sourcecode language="vb"]
<%@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 '得到当前文件夹的物理路径
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("1.txt"))
If objXmlFile.readyState=4 Then
If objXmlFile.parseError.errorCode = 0 Then
Set objNodeList = objXmlFile.documentElement.selectNodes("//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 "创建目录" & objNodeList(i).text & "
"
Response.Flush
Next
Set objFSO = nothing
Set objNodeList = nothing
Set objNodeList = objXmlFile.documentElement.selectNodes("//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 & "
"
Response.Flush
.Close
End With
Set objStream = Nothing
Next
Set objNodeList = nothing
End If
End If
Set objXmlFile = Nothing
response.write "文件解包完毕"
%>
</body>
</html>
[/sourcecode]

OK,大功告成,剩下的自己知道该怎么做了吧?呵呵。
关键字: ASP,打包

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。