av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

asp下利用xml打包網(wǎng)站文件

瀏覽:185日期:2022-06-04 13:55:40
這個(gè)方法可以把整個(gè)文件夾打包到xml文件中,把這個(gè)xml文件文件和解包文件放在一起后,運(yùn)行解包文件就可以把原來(lái)的文件釋放出來(lái),這樣我們就可以把網(wǎng)站打包上傳到虛擬主機(jī),再運(yùn)行解包文件就可以了。我在本地測(cè)試之選擇了少部分文件,不知在文件很多的情況執(zhí)行效率如何。
    其實(shí)實(shí)現(xiàn)的思路也很簡(jiǎn)單,主要利用的是xml文件可以存放二進(jìn)制數(shù)據(jù)的原理。有興趣的朋友可以下載下面的附件研究下!!
解包文件
復(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>——文件解包程序_www.jb51.net</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>

pack.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>文件打包程序__www.jb51.net</title>
</head>

<body>
<%
Dim ZipPathDir,ZipPathFile
Dim startime,endtime
"在此更改要打包文件夾的路徑
ZipPathDir = "D:\testasp\dictionary\xmlPacked\scrollColor""
ZipPathFile = "update.xml"
if right(ZipPathDir,1)<>"\" then ZipPathDir=ZipPathDir&"\"
"開(kāi)始打包
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")) 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
            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)
    "程序開(kāi)始執(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("頁(yè)面執(zhí)行時(shí)間:" & FormatNumber((endtime-startime),3) & "秒")
end sub
%>
</body>
</html>
標(biāo)簽: XML/RSS
相關(guān)文章:
主站蜘蛛池模板: 1级毛片| 国产视频福利在线观看 | 亚洲一二三在线 | 美女黄网站| 亚洲精品国产a久久久久久 午夜影院网站 | 久久久久久女 | 欧美在线观看一区 | 欧美日韩国产精品一区 | 久久激情av | 国产一区二区在线视频 | 久久9热| 国产一区二区成人 | 国产一区二区在线视频 | 久久国产欧美日韩精品 | a级毛片国产 | 国产精品视频一区二区三 | 成人免费一区二区三区牛牛 | 欧美另类视频 | 色黄爽| 一区二区三区视频在线 | 久久免费观看视频 | 激情在线视频网站 | 亚洲一区在线日韩在线深爱 | 欧美激情第一区 | 国产精品小视频在线观看 | 中文字幕日韩欧美 | 中文字幕国产精品 | 亚洲欧美成人 | 一级a爱片久久毛片 | 91xxx在线观看| 91精品久久久久久久久中文字幕 | 欧美黑人一级爽快片淫片高清 | 欧洲精品码一区二区三区免费看 | 久久久免费电影 | 一区二区久久 | 日日久 | 欧美一区久久 | 在线看h| 91婷婷韩国欧美一区二区 | 中文字幕高清 | 久久国产麻豆 |