asptar.asp文件 复制全部代码 0 then sFilename = Right(sFilename,Len(sFilename) - lTemp) end if sFilename = BasePath & sFilename End If ' Build the header, everything is ASCII in octal except for the data 'objOutStream.charset="gb2312" objOutStream.WriteText Left(sFilename & String(100,Chr(0)),100) 'objOutStream.charset="x-ansi" objOutStream.WriteText "100" & Right("000" & Oct(Permissions),3) & " " & Chr(0) 'File mode objOutStream.WriteText Right(String(6," ") & CStr(UserID),6) & " " & Chr(0) 'uid objOutStream.WriteText Right(String(6," ") & CStr(GroupID),6) & " " & Chr(0) 'gid objOutStream.WriteText Right(String(11,"0") & Oct(objInStream.Size),11) & Chr(0) 'size objOutStream.WriteText Right(String(11,"0") & Oct(dateDiff("s","1/1/1970 10:00",now())),11) & Chr(0) 'mtime (Number of seconds since 10am on the 1st January 1970 (10am correct?) objOutStream.WriteText " 0" & String(100,Chr(0)) 'chksum, type flag and link name, write out all blanks so that the actual checksum will get calculated correctly objOutStream.WriteText "ustar " & Chr(0) 'magic and version objOutStream.WriteText Left(UserName & String(32,Chr(0)),32) 'uname objOutStream.WriteText Left(GroupName & String(32,Chr(0)),32) 'gname objOutStream.WriteText " 40 " & String(4,Chr(0)) 'devmajor, devminor objOutStream.WriteText String(167,Chr(0)) 'prefix and leader objInStream.CopyTo objOutStream ' Send the data to the stream if (objInStream.Size Mod BlockSize) > 0 then objOutStream.WriteText String(BlockSize - (objInStream.Size Mod BlockSize),Chr(0)) 'Padding to the nearest block byte boundary end if ' Calculate the checksum for the header lSum = 0 objOutStream.Position = lStart For lTemp = 1 To BlockSize lSum = lSum + (Asc(objOutStream.ReadText(1)) And &HFF&) Next ' Insert it objOutStream.Position = lStart + 148 objOutStream.WriteText Right(String(7,"0") & Oct(lSum),7) & Chr(0) ' Move to the end of the stream objOutStream.Position = objOutStream.SizeEnd Sub' Start everything offPrivate Sub Class_Initialize() Set objFiles = Server.CreateObject("Scripting.Dictionary") Set objMemoryFiles = Server.CreateObject("Scripting.Dictionary") BlockSize = 512 Permissions = 438 ' UNIX 666 UserID = 0 UserName = "root" GroupID = 0 GroupName = "root" IgnorePaths = False BasePath = "" TarFilename = "new.tar"End SubPrivate Sub Class_Terminate() Set objMemoryFiles = Nothing Set objFiles = NothingEnd SubEnd Class%>[/quote],Bullcn'Blog - 分享、交流、进步。" /> [转]不用额外组件的ASP在线打包程序 - Bullcn'Blog

[转]不用额外组件的ASP在线打包程序


  现在一般的在线打包都需要winrar程序的支持,下面介绍一种不用winrar支持的在线打包程序,源代码好像是个老外写的,有个缺陷就是打包的时候如果文件名是中文,就会出现乱码,庆幸的是文件的内容不会产生乱码,并且可以用winrar解压.
  下面是具体的程序,也可以到这里来下载:http://www.ii-home.cn/upfiles/zip.rar
index.asp文件

引用内容 引用内容


<% Option Explicit %>
<!--#include file="asptar.asp"-->
<%
Response.charset="gb2312"
Response.Buffer = True
Response.Clear
Dim Co,Temp,T,x,i,fsoBrowse,theFolder,TheSubFolders,FilePath,s,PH,objTar
Co=0
PH="../zip" '文件路径 '压缩父目录下zip目录的所有文件
   Set objTar = New Tarball
   objTar.TarFilename="打包.rar"  '打包的名称
   objTar.Path=PH
   set fsoBrowse=CreateObject("Scripting.FileSystemObject")
   Set theFolder=fsoBrowse.GetFolder(Server.Mappath(PH))
   Set theSubFolders=theFolder.SubFolders
   GetFileList theFolder,""
  
   If Co<1 Then
      Response.Write "暂时没有可更新的文件下载"
   'objTar.AddMemoryFile "Sorry.txt","Not File!"
   Else
      Temp=Left(Temp,Len(Temp)-1)
      FilePath=Split(Temp,"|")
      For s=0 To Ubound(FilePath)
        objTar.AddFile Server.Mappath(PH & "/" & FilePath(s))
      Next
   If Response.IsClientConnected Then
        objTar.WriteTar
        Response.Flush
   End If
   End If
   Set ObjTar = Nothing
   Set fsoBrowse= Nothing
   Set theFolder = Nothing
   Set theSubFolders = Nothing
Sub GetFileList(Folderobject,path)
Dim y,m
For Each y in Folderobject.Files
If Path <>"" Then
Temp= Temp &  path & y.Name&"|"
Else
Temp= Temp & y.Name&"|"
End If
    Co=Co+1
Next
Dim NewPath
For Each m In Folderobject.SubFolders
If path="" Then
NewPath=M.name &"/"
Else
NewPath=path & M.name &"/"
End If
GetFileList m,NewPath
Next
End Sub
%>

asptar.asp文件
    复制全部代码

<%

Class Tarball
Public TarFilename   ' Resultant tarball filename

Public UserID    ' UNIX user ID
Public UserName    ' UNIX user name
Public GroupID    ' UNIX group ID
Public GroupName   ' UNIX group name

Public Permissions   ' UNIX permissions

Public BlockSize   ' Block byte size for the tarball (default=512)

Public IgnorePaths   ' Ignore any supplied paths for the tarball output
Public BasePath    ' Insert a base path with each file
Public Path

' Storage for file information
Private objFiles,TmpFileName
Private objMemoryFiles

' File list management subs, very basic stuff
Public Sub AddFile(sFilename)
  objFiles.Add sFilename,sFilename
End Sub

Public Sub RemoveFile(sFilename)
  objFiles.Remove sFilename
End Sub

Public Sub AddMemoryFile(sFilename,sContents)
  objMemoryFiles.Add sFilename,sContents
End Sub

Public Sub RemoveMemoryFile(sFilename)
  objMemoryFiles.Remove sFilename
End Sub

Public Sub WriteTar()
  Dim objStream, objInStream, lTemp, aFiles
  Set objStream = Server.CreateObject("ADODB.Stream") ' The main stream
  Set objInStream = Server.CreateObject("ADODB.Stream") ' The input stream for data
  objStream.Type = 2
  objStream.Charset = "x-ansi" ' Good old extended ASCII
  objStream.Open

  objInStream.Type = 2
  objInStream.Charset = "x-ansi"

  aFiles = objFiles.Items
  For lTemp = 0 to UBound(aFiles)
    objInStream.Open
    objInStream.LoadFromFile aFiles(lTemp)
    objInStream.Position = 0
    TmpFileName =replace(aFiles(lTemp),Server.Mappath(Path)&"\","")
    ExportFile TmpFileName,objStream,objInStream
    objInStream.Close
  Next
  aFiles = objMemoryFiles.Keys
  For lTemp = 0 to UBound(aFiles)
    objInStream.Open
    objInStream.WriteText objMemoryFiles.Item(aFiles(lTemp))
    objInStream.Position = 0
    ExportFile aFiles(lTemp),objStream,objInStream
    objInStream.Close
  Next

  objStream.WriteText String(BlockSize,Chr(0))
  objStream.Position = 0
  objStream.Type = 1
  objStream.savetofile Server.Mappath(Path) & "\" & TarFilename,2
  objStream.Close
  Set objStream = Nothing
  Set objInStream = Nothing
End Sub

' Build a header for each file and send the file contents
Private Sub ExportFile(sFilename,objOutStream,objInStream)
  Dim lStart, lSum, lTemp
  lStart = objOutStream.Position ' Record where we are up to
  If IgnorePaths Then
   ' We ignore any paths prefixed to our filenames
   lTemp = InStrRev(sFilename,"\")
   if lTemp <> 0 then
    sFilename = Right(sFilename,Len(sFilename) - lTemp)
   end if
   sFilename = BasePath & sFilename
  End If
  
  ' Build the header, everything is ASCII in octal except for the data
  'objOutStream.charset="gb2312"
  objOutStream.WriteText Left(sFilename & String(100,Chr(0)),100)
  'objOutStream.charset="x-ansi"
  objOutStream.WriteText "100" & Right("000" & Oct(Permissions),3) & " " & Chr(0) 'File mode
  objOutStream.WriteText Right(String(6," ") & CStr(UserID),6) & " " & Chr(0) 'uid
  objOutStream.WriteText Right(String(6," ") & CStr(GroupID),6) & " " & Chr(0) 'gid
  objOutStream.WriteText Right(String(11,"0") & Oct(objInStream.Size),11) & Chr(0) 'size
  objOutStream.WriteText Right(String(11,"0") & Oct(dateDiff("s","1/1/1970 10:00",now())),11) & Chr(0) 'mtime (Number of seconds since 10am on the 1st January 1970 (10am correct?)
  objOutStream.WriteText "        0" & String(100,Chr(0)) 'chksum, type flag and link name, write out all blanks so that the actual checksum will get calculated correctly
  objOutStream.WriteText "ustar  "  & Chr(0) 'magic and version
  objOutStream.WriteText Left(UserName & String(32,Chr(0)),32) 'uname
  objOutStream.WriteText Left(GroupName & String(32,Chr(0)),32) 'gname
  objOutStream.WriteText "         40 " & String(4,Chr(0)) 'devmajor, devminor
  objOutStream.WriteText String(167,Chr(0)) 'prefix and leader
  objInStream.CopyTo objOutStream ' Send the data to the stream
  
  if (objInStream.Size Mod BlockSize) > 0 then
   objOutStream.WriteText String(BlockSize - (objInStream.Size Mod BlockSize),Chr(0)) 'Padding to the nearest block byte boundary
  end if
  
  ' Calculate the checksum for the header
  lSum = 0  
  objOutStream.Position = lStart
  
  For lTemp = 1 To BlockSize
   lSum = lSum + (Asc(objOutStream.ReadText(1)) And &HFF&)
  Next
  
  ' Insert it
  objOutStream.Position = lStart + 148
  objOutStream.WriteText Right(String(7,"0") & Oct(lSum),7) & Chr(0)
  
  ' Move to the end of the stream
  objOutStream.Position = objOutStream.Size
End Sub

' Start everything off
Private Sub Class_Initialize()
  Set objFiles = Server.CreateObject("Scripting.Dictionary")
  Set objMemoryFiles = Server.CreateObject("Scripting.Dictionary")
  
  BlockSize = 512
  Permissions = 438 ' UNIX 666
  UserID = 0
  UserName = "root"
  GroupID = 0
  GroupName = "root"
  IgnorePaths = False
  BasePath = ""
  TarFilename = "new.tar"
End Sub

Private Sub Class_Terminate()
  Set objMemoryFiles = Nothing
  Set objFiles = Nothing
End Sub
End Class
%>


文章来自: 本站原创
引用通告: 查看所有引用 | 我要引用此文章
Tags: 打包
相关日志:
评论: 0 | 引用: 0 | 查看次数: 429
发表评论
昵 称:
密 码: 游客发言不需要密码.
内 容:
验证码: 验证码
选 项:
虽然发表评论不用注册,但是为了保护您的发言权,建议您注册帐号.
字数限制 20 字 | UBB代码 关闭 | [img]标签 关闭