佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 用asp實現(xiàn)把文件打包成Xml文件包,帶解包的ASP工具附下載

用asp實現(xiàn)把文件打包成Xml文件包,帶解包的ASP工具附下載

熱門標簽:服務(wù)器配置 銀行業(yè)務(wù) Mysql連接數(shù)設(shè)置 阿里云 科大訊飛語音識別系統(tǒng) Linux服務(wù)器 電子圍欄 團購網(wǎng)站
把文件打包成Xml文件包,帶解包的ASP工具!

把網(wǎng)站源碼全部打包到Xml文件里面,生成 updata.xml 文件,把xml文件上傳到空間里面
然后通過 install.asp文件將文件全部釋放出來。
就和z-blog的 自動安裝包一樣的功能呵呵。
代碼是落伍的一位兄弟寫的,不過代碼好像有錯誤,這個是我參考他的 修改過了,可以正常運行!~~
此代碼可以應用到 asp程序的 自動升級服務(wù)上面。具體怎么來實現(xiàn),歡迎探討!~~
就在下面回帖探討!~~~
不用設(shè)定打包目錄版,需要設(shè)定打包目錄版 這兩個版本的區(qū)別:
不用設(shè)定打包目錄版,直接放到你需要打包的目錄 執(zhí)行就可以了。
需要設(shè)定打包目錄版,必須指定需要打包的路徑(在程序里修改),不指定,不能進行打包。
不用設(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"
    '不進行打包的文件擴展名
    ZipFileExt = "db;bak"
    if right(ZipPathDir,1)>"\" then ZipPathDir=ZipPathDir"\"
    '開始打包
    CreateXml(ZipPathFile)
    '遍歷目錄內(nèi)的所有文件以及文件夾
    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)'創(chuàng)建文件夾對象

        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")) 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)建的子文件夾對象
        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)建一個空的XML文件,為寫入文件作準備
    sub CreateXml(FilePath)
        '程序開始執(zhí)行時間
        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é)束時間
        endtime=timer()
        response.Write("頁面執(zhí)行時間:"  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
    '得到當前文件夾的物理路徑
    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>

打包文件下載

標簽:蚌埠 廣元 萍鄉(xiāng) 棗莊 衡水 大理 江蘇 衢州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《用asp實現(xiàn)把文件打包成Xml文件包,帶解包的ASP工具附下載》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    安岳县| 江永县| 宜城市| 和田市| 中超| 呈贡县| 乌兰县| 儋州市| 临洮县| 宜宾县| 察隅县| 孝义市| 富蕴县| 射阳县| 绥阳县| 康平县| 九龙县| 碌曲县| 融水| 文山县| 赣榆县| 青州市| 岳池县| 循化| 洪洞县| 莱阳市| 乳山市| 浠水县| 崇义县| 根河市| 深泽县| 宁强县| 江津市| 武义县| 车致| 石屏县| 乐清市| 花莲市| 额济纳旗| 若尔盖县| 板桥市|