学习无忧
开发频道 首页 | 入门 | 硬件 | 软件 | 设计 | 开发 | 网络 | 营销 | 社区 | 加油站
首页=>开发=>ASP=>[ASP]利用 xmlhttp 分块上传文件  
[ASP]利用 xmlhttp 分块上传文件
www.51study.net  2004-7-2 17:38  来源:学习无忧网
【字体:  】【评论打印】 【关闭
  编写思路:把本地文件在客户端通过base64编码以后发送目的地.
  测试过程中,上传文件过大,导致超时不成功.
  后来经过改善.把编码分段发送.测试20M成功
  
  编写目的:在传统的解决方案里面,一次一次选取上传可以.但是在碰到把数据库里文件路径读出来,并把这些文件上传到一个地方的时候就比较麻烦.
  如果得到路径一个一个去找到用ftp当然也是可以的,但每次找这些文件我看都会比较费时。这里编写这个主要就是为了通过数据库里的文件路径取得文件.把文件一次批量上传到一个地方.
  其主要目的还是为了锻炼一下自己.
  
  解决过程:起初试着用模拟键盘输入强行赋值给file控件用传统的方法上传。可是老碰到空值的情况,以至有很多文件没有发送出去。查阅一些资料,现在是把所有路径通过数据库取到然后写到一个js里。然后在前台用js读取这些路径,通过xmlhttp来发送文件。
  因为ie不太喜欢xmlHttp.总认为他有恶意行为.所以老谈出提示警告.所以操作的时候不能使用web路径.只能用物理路径去访问它.
  然后服务端有一文件来接收这些编码,并对其进行解码.所以我称之为"c/s". ^_^
  
  目前很多代码还在完善中.
  简单介绍一下:
  
  aryFiles.push("c:\\aaa.zip") ;
  aryFiles.push("c:\\bbb.exe") ;
  这里为文件路径和文件.可为多个
  以后这个路径也可以通过file控件在客户端取到
  
  http:// www.xxx.com/xxx/xxx.asp
  这个是目的地,可以改为自己想要的地址.
  
  ado_stream.LoadFromFile(server.mappath(".") &"/"& + str_filename)
  server.mappath(".") &"/"& + str_filename 这里是读取文件.
  server.mappath(".") &"/"& 路径和存放路径一致
  
  ado_stream.SaveToFile server.mappath(".") &"/"& str_filename,2
  server.mappath(".") &"/"& 这个为存放文件的路径. str_filename 为文件名
  
  这里读取和存放都是放在程序所放目录中.大家测试的时候也可以保持这样即可
  
  把第一段代码放到本地(eg:c:\upload.htm)
  
  把第二段代码放到服务器上,可以是本地服务器,可以是公网服务器.和上面的目的地保持一致
  (eg:http://www.xxx.com/upload.asp or http:// localhost/www/upload.asp)
  
  
  操作:找到第一段代码保存的地方。执行即可(eg:打开c盘执行upload.htm)
  
  客户端代码
  
  
  
     value="发送" />   Breaked=true;" value="中断" />
  width=300px>


  id=div_message>
  
  
  
  
  服务端代码
  <%@ LANGUAGE=VBScript%>
  <% Option Explicit
  Response.Expires = 0
  
  ' 定义变量和对象。
  dim ado_stream
  dim xml_dom
  dim xml_data
  dim str_filename
  dim bol_PartStart
  dim int_PartID
  dim bol_PartEnd
  
  ' 创建 Stream 对象
  set ado_stream = Server.CreateObject("ADODB.Stream")
  ' 从Request对象创建 XMLDOM对象
  set xml_dom = Server.CreateObject("MSXML2.DOMDocument")
  xml_dom.load(request)
  ' 读出包含二进制数据的节点
  set xml_data = xml_dom.selectSingleNode("root/upData")
  str_filename = xml_data.getAttribute("FileName")
  bol_PartStart = CBool(xml_data.getAttribute("PartStart"))
  int_PartID = CInt(xml_data.getAttribute("PartID"))
  bol_PartEnd = CBool(xml_data.getAttribute("PartEnd"))
  
  ' 打开Stream对象,把数据存入其中
  ado_stream.Type = 1 ' 1=adTypeBinary
  ado_stream.open
  if not bol_PartStart then
   ado_stream.LoadFromFile(server.mappath(".") &"/"& + str_filename) ' 读取文件
   ado_stream.position = ado_stream.size
  end if
  ado_stream.Write xml_data.nodeTypedValue
  ' 文件存盘
  ado_stream.SaveToFile server.mappath(".") &"/"& str_filename,2
  '保存文件 2=adSaveCreateOverWrite
  ado_stream.close
  
  ' 释放资源
  set ado_stream = Nothing
  set xml_dom = Nothing
  ' 向浏览器返回信息
  Response.Write "Upload successful!"& str_filename & int_PartID & bol_PartStart
  %>
  另外:此文的目的并不是说这个程序能给朋友们解决什么问题,主要目的还是为了和大家交流一些心得:
  碰到问题->发现问题->解决问题.
  希望大家都不要成为一个标准的代码机器人。
  多学、多看、多思考、多实践。
  没有什么是不能解决的。
【字体:  】【评论打印】 【关闭
发表评论 共有0条评论   >> 查看详细评论
用户名: 密 码: 匿名评论
请发表评论时遵纪守法并注意语言文明!
 
用户名 评论内容
目前尚无评论!
 
文章搜索
关键字:
精彩文章回顾
 SQL Server 2
 ASP、JSP、PHP
 利用ASP技术开发基于W
 WORD和ACCESS的
 Access 数据库表规
 SQL Server的性
 SQL 非正常删除日志文
 拷贝的SQL Serve
广而告之
关于我们 | 广告服务 | 诚邀加盟 | 友情链接 | 网站地图 | 联系方式
Copyright ©1998-2005, All Rights Reserved.
版权所有 学习无忧网 51study.net
广告或空间合作,请QQ:70046085联系我