新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> XML网站展示,XML源代码,XML编程示例。 本版仅接受原创、转贴、网站展示,具体的技术交流请前往各相关版块。
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XML源码及示例(仅原创和转载) 』 → [原创][下载]利用XML打包指定文件夹 并上传到WEB目录中,自行解包 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 6933 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [原创][下载]利用XML打包指定文件夹 并上传到WEB目录中,自行解包 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     renxiang0731 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:1
      积分:64
      门派:XML.ORG.CN
      注册:2005/8/1

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给renxiang0731发送一个短消息 把renxiang0731加入好友 查看renxiang0731的个人资料 搜索renxiang0731在『 XML源码及示例(仅原创和转载) 』的所有贴子 引用回复这个贴子 回复这个贴子 查看renxiang0731的博客楼主
    发贴心情 [原创][下载]利用XML打包指定文件夹 并上传到WEB目录中,自行解包

    前两天下了个Z-BLOG,发现其安装程序有点意思,只有两个文件,一个数据文件,XML格式的,一个解包程序

    此程序仿照Z-BLOG的安装程序数据文件逆向写出
    希望对那些不能批量上传文件的网友有帮助
    程序中如有问题或见解,还请大家指出。。
    QQ:50489390

    '========================
    '文件1
    'Pack.asp
    '更改 Cpathname 这一变量
    '将在当前目录生成一个DATA.XML文件
    '将DATA.XML及文件2(install.asp)上传至WEB根目录
    '运行install.asp解包
    '手动删除以上两个文件
    '========================
    <% Option Explicit %>
    <% On Error Resume Next %>
    <%
    Server.ScriptTimeout=99999999
    dim Cpathname
    dim startime,endtime

    '在此更改要打包文件夹的路径
    Cpathname = "F:\WEB\symr"

    startime=timer()
    function bianli(path)
     dim doc
        dim fso            'fso对象
        dim objFolder      '文件夹对象
        dim objSubFolders  '子文件夹集合
        dim objSubFolder   '子文件夹对象
        dim objFiles       '文件集合
        dim objFile        '文件对象
     dim objStream
        dim pathname,TextStream,pp,Xfolder,Xfpath,Xfile,Xpath,Xstream

        set fso=server.CreateObject("scripting.filesystemobject")
        set objFolder=fso.GetFolder(path)'创建文件夹对象
        
        Response.Write path
        Response.flush
        
     Set doc = Server.CreateObject("MSxml2.DOMDocument")
     doc.load Server.MapPath("data.xml")
     doc.async=false
     
     '写入每个文件夹路径
     set Xfolder = doc.SelectSingleNode("//z-blog").AppendChild(doc.CreateElement("folder"))
     Set Xfpath = Xfolder.AppendChild(doc.CreateElement("path"))
     Xfpath.text = replace(path,Cpathname,"")
        
        set objFiles=objFolder.Files
        for each objFile in objFiles
            Response.Write "
    ---"
         pp = path & "\" & objFile.name
         
             Response.Write pp & "
    "
          Response.flush

          '================================================
          '写入文件的路径及文件内容
       set Xfile = doc.SelectSingleNode("//z-blog").AppendChild(doc.CreateElement("file"))
       
       Set Xpath = Xfile.AppendChild(doc.CreateElement("path"))
       Xpath.text = replace(pp,Cpathname,"")
       
       '创建文件流读入文件内容,并写入XML文件中
       Set objStream = Server.CreateObject("ADODB.Stream")
       objStream.Type = 1
       objStream.Open()
       objStream.LoadFromFile(pp)
       objStream.position = 0
       
       Set Xstream = Xfile.AppendChild(doc.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
       
          '================================================
        next
        Response.Write "<p>"
     
     doc.save server.mappath("data.xml")
     set Xfpath = nothing
     set Xfolder = nothing
        set doc = nothing
        
     '创建的子文件夹对象
     set objSubFolders=objFolder.Subfolders
        '调用递归遍历子文件夹
        for each objSubFolder in objSubFolders
      pathname=path + "\" + objSubFolder.name
      bianli(pathname)
        next
        
        set objFolder=nothing
        set objSubFolders=nothing
        set fso=nothing
    end function

    dim doc,objPI
    '创建一个空的XML文件,为写入文件作准备
    Set doc = Server.CreateObject("MSxml2.DOMDocument")
    doc.async=false
    set objPI = doc.createProcessingInstruction("xml","version='1.0' encoding='UTF-8'")
    doc.insertBefore objPI, doc.childNodes(0)
    doc.appendChild(doc.CreateElement("z-blog"))
    doc.save server.mappath("data.xml")
    set objPI = nothing
    set doc = nothing
    bianli(Cpathname)
    endtime=timer()
    %>
    页面执行时间:<%=FormatNumber((endtime-startime),3)%>秒

    '=================================
    '文件2
    'install.asp
    '此文件改自z-blog安装文件
    '=================================
    <%@ CODEPAGE=65001 %>
    <% Option Explicit %>
    <% On Error Resume Next %>
    <% Response.Charset="UTF-8" %>
    <html>
    <head>
    <title>文件解包程序</title>
    </head>
    <body>
    <textarea name="content" cols="90" rows="20" style="border:0px;overflow:auto;border-width:0px;width:100%;background-color:#E8F3FF;" scrolling="auto">
    <%
     Dim strLocalPath
     '得到当前文件夹的物理路径
     strLocalPath=Left(Request.ServerVariables("PATH_TRANSLATED"),InStrRev(Request.ServerVariables("PATH_TRANSLATED"),"\"))

     Dim strDbPath
     Dim objXmlFile
     Dim objNodeList
     Dim objFSO
     Dim objStream
     Dim i,j

     Set objXmlFile = Server.CreateObject("Microsoft.XMLDOM")
     objXmlFile.load(Server.MapPath("data.xml"))

    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 & vbCrlf
       Response.Flush
      Next

      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 & vbCrlf
       Response.Flush
       .Close
       End With
       Set objStream = Nothing
      Next
     End If
    End If
    %>
    </textarea>
    <%response.write "<script>alert('文件解包完毕!');</script>"%>

    ================================================
    不想COPY的,这里有源文件下载


    ================================================


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/5 11:53:00
     
     tloner 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(高数修炼中)
      文章:12
      积分:105
      门派:XML.ORG.CN
      注册:2005/11/10

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给tloner发送一个短消息 把tloner加入好友 查看tloner的个人资料 搜索tloner在『 XML源码及示例(仅原创和转载) 』的所有贴子 引用回复这个贴子 回复这个贴子 查看tloner的博客2
    发贴心情 
    好东西,收藏了
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/24 11:31:00
     
     fangzi 帅哥哟,离线,有人找我吗?处女座1980-9-18
      
      
      等级:大一新生
      文章:1
      积分:60
      门派:XML.ORG.CN
      注册:2005/10/1

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给fangzi发送一个短消息 把fangzi加入好友 查看fangzi的个人资料 搜索fangzi在『 XML源码及示例(仅原创和转载) 』的所有贴子 访问fangzi的主页 引用回复这个贴子 回复这个贴子 查看fangzi的博客3
    发贴心情 
    好东西,收藏

    ----------------------------------------------
    [url=http://www.notepad.com.cn]记事专家-专业的网络记事本[/url]

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/12/21 9:30:00
     
     algorithm 帅哥哟,离线,有人找我吗?
      
      
      等级:大二期末(Java考了96分!)
      文章:69
      积分:368
      门派:XML.ORG.CN
      注册:2005/12/8

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给algorithm发送一个短消息 把algorithm加入好友 查看algorithm的个人资料 搜索algorithm在『 XML源码及示例(仅原创和转载) 』的所有贴子 引用回复这个贴子 回复这个贴子 查看algorithm的博客4
    发贴心情 
    COOL
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/1/7 16:32:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XML源码及示例(仅原创和转载) 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/11 15:54:28

    本主题贴数4,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    93.750ms