婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > asp下利用xml打包網站文件

asp下利用xml打包網站文件

熱門標簽:南寧網絡外呼系統運營商 隨州外呼調研系統 微信地圖標注合并了 東營電銷 本地電話機器人 r語言數據可視化地圖標注 400電話辦理包年 高德地圖地圖標注服務中心 如何修改多個百度地圖標注
這個方法可以把整個文件夾打包到xml文件中,把這個xml文件文件和解包文件放在一起后,運行解包文件就可以把原來的文件釋放出來,這樣我們就可以把網站打包上傳到虛擬主機,再運行解包文件就可以了。我在本地測試之選擇了少部分文件,不知在文件很多的情況執行效率如何。
    其實實現的思路也很簡單,主要利用的是xml文件可以存放二進制數據的原理。有興趣的朋友可以下載下面的附件研究下!!
解包文件
復制代碼 代碼如下:

%@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
'得到當前文件夾的物理路徑
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 "創建目錄"  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 打包文件
復制代碼 代碼如下:

%@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"\"
'開始打包
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("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
                    '================================================
                    '寫入文件的路徑及文件內容
                   set Xfile = XmlDoc.SelectSingleNode("http://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>

標簽:寧夏 黃石 果洛 西雙版納 宿遷 拉薩 德州 益陽

巨人網絡通訊聲明:本文標題《asp下利用xml打包網站文件》,本文關鍵詞  asp,下,利用,xml,打包,網站,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp下利用xml打包網站文件》相關的同類信息!
  • 本頁收集關于asp下利用xml打包網站文件的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 和田县| 上犹县| 浏阳市| 当雄县| 洛阳市| 长丰县| 湘阴县| 文山县| 韩城市| 宁阳县| 莲花县| 运城市| 荥阳市| 盐城市| 桂林市| 北流市| 诏安县| 乌苏市| 汉源县| 清徐县| 米林县| 水城县| 扎兰屯市| 大理市| 司法| 邹城市| 视频| 肇源县| 东城区| 彭阳县| 偏关县| 五大连池市| 博白县| 台东市| 咸宁市| 赣州市| 襄樊市| 台北市| 永济市| 嘉义县| 宝兴县|