绝对绿茶 发表于 2015-5-29 06:42:47

FTP文件上传控件开发文档-Xproer.FtpUploader2

版权所有 2009-2012 武汉命运科技有限公司
保留所有权利
产品博客:http://www.iyunv.com/xproer/
官方网站:http://www.ncmem.com/
产品首页:http://www.ncmem.com/webplug/ftp-uploader2/index.aspx
在线演示:http://www.ncmem.com/products/file-uploader/demo/index.html
开发文档:http://www.iyunv.com/xproer/archive/2011/03/15/1984413.html
升级日志:http://www.iyunv.com/xproer/archive/2011/04/04/2005251.html


资源下载:cab安装包,开发文档,示例下载,VC库
联系信箱:1085617561@qq.com
联系QQ:1085617561

1.      概述
FtpUploader2在FtpUploader的基础上进行了大幅度调整和优化。
首先在FtpUploader中是使用单独的线程来计算即时上传速度的,在某些情况下计算结果可能会出现较大的误差。在FtpUploader2中我们取消了单独的速度计算线程,将速度计算与上传模块整合在一起,使速度计算更加精确。
在客户端调用方面(JavaScript)我们在COM组件中提供了一个JS对象指针,用来保存客户端的FtpUploader对象,在组件事件中将这个JS对象指针传给客户端,这样极大的简化了客户端开发模式。
在即时速度计算方面,我们取消了JS的定时调用,装饰速度计算的任务完全交给COM组件来进行。降低了线程同步访问的风险。
与FtpUploader相比FtpUploader2更稳定,更高效,开发也更简单。

2.      快速开始
2.1.   架设FTP服务器
新颖网络FTP文件上传插件支持Microsoft FTP,Serv-U和FileZilla。
以下分别为FTP服务器的架设教程:
安装ServU—7.1:http://www.iyunv.com/xproer/archive/2010/11/20/1882370.html
安装ServU-6.4.0.6:http://www.iyunv.com/xproer/archive/2011/03/28/1998042.html
安装FileZilla Server:http://www.iyunv.com/xproer/archive/2010/12/23/1914588.html
安装Microsoft FTP Server:http://www.iyunv.com/xproer/archive/2011/03/06/1972192.html

2.2.   添加测试帐号
由于测试版FtpUploader只能连接127.0.0.1服务器,且只能以test帐号登陆,所以在演示时需要添加test帐号。
帐号:test
密码:test

2.3.   配置FTP信息
var manager = new FileTransferManager("FilePostLister");
manager.Config["Server"] = "127.0.0.1";//测试版插件只能连接这个IP
manager.Config["UserName"] = "test";//设置FTP用户名
manager.Config["UserPass"] = "test";//设置FTP密码
manager.Config["RemoteFolder"] = "upload";//设置FTP上传目录

2.4.   运行示例
在IE中打开文件FtpUploader.html

3.      JavaScript对象
3.1.   FileUploader对象
类型:JavaScript
文件上传对象的包装类,用户在实际的项目中只需要创建FileUploader对象,然后通过FileUploader对象就可以进行文件上传操作。

语法:

JavaScript(声明)
function FileUploader() { }

方法

名称
说明

Ready
指示文件上传对象准备完毕

Post
开始上传文件

Stop
停止文件上传

PostNext
继续传输上传队列中的下一个文件


Ready方法
将上传任务状态设置为准备状态。
Post方法
开始上传文件。
说明:此函数将会自动实现断点续传功能。如果当前任务文件只上传了一半,则在下次开始时XSUploader组件将会自动定位到上次上传的位置继续上传数据。
Stop方法
停止上传任务。
PostNext方法
继续上传队列中下一个任务。

属性

名称
说明

pMsg
消息对象。是一个DIV

pProcess
上传进度条对象。是一个DIV

pPercent
上传进度百分比对象。是一个DIV

pButton
控制按钮对象。是一个A

LocalFile
包含完整路径的本地文件名称。例:C:\qq.exe


3.2.   FileTransferManager对象
类型:JavaScript
文件上传管理类。

构造函数
FileTransferManager(fileListDivId)
参数:
fileListDiv
   上传列表的DIV对象ID名称。文件上传管理对象会将每一个文件的上传信息添加到此DIV中。
   注意:此DIV必须存在,此DIV的ID必须唯一。

方法
AddFile方法
添加一个文件到上传对列中

语法:
void AddFile(fid);

参数:
fid
新上传任务的文件ID,此ID用来区域不同的上传任务。必须保证唯一。

PostFirst方法
开始上传队列中的第一个文件。

语法:
void PostFirst()

Exist方法
检查上传队列中是否存在指定文件。

语法:
bool Exist();

返回值:
   true
表示存在。
   false
不存在。

说明:此函数是根据本地文件的完整路径来检测的。
属性
Config属性
提供插件的全局配置信息。在项目如果需要修改插件的配置信息,只需要通Config属性来控件即可。

语法:
this.Config = {
         "Server"      : "127.0.0.1"
         , "UserName": "test"
         , "UserPass": "test"
         , "RemoteFolder": ""
         , "Port"      : 21
   };

示例-设置插件信息
    var manager = new FileTransferManager("FilePostLister");
    manager.Config["Server"] = "tel.ftp.u.115.com:21";
    manager.Config["UserName"] = "1199925";
    manager.Config["UserPass"] = "4b29da413f";
    manager.Config["RemoteFolder"] = "upload";

4.      ActiveX对象
4.1.   Xproer.UploaderPartition2对象
CLSID:9463F939-F485-404f-9FB0-8729E82DE11F
类型:ActiveX
多文件选择对象。弹出一个文件选择对话框,为用户提供选择多个文件的功能。
方法

名称
说明

ShowDialog
弹出文件选择对话框

GetSelectedFiles
获取用户选择的文件列表


GetSelectedFiles方法
获取用户选择的文件列表数组。

示例
下面的代码示例将会创建一个文件选择框,并弹出用户所选择的文件名称。

JavaScript:

   function ShowSelectFileDlg()
   {
         var manager = new FileTransferManager("FilePostLister");
         var obj = new ActiveXObject("Xproer.UploaderPartition2");//创建文件选择对话框

         if (!obj.ShowDialog()) return;
         var list = obj.GetSelectedFiles();//获取用户选择的文件
         if (list.lbound(1) == null) return;

         for (var index = list.lbound(1); index



   var obj = document.getElementById("FilePanel1");
   obj.OnFileDrop = EventFileDrop;
   function EventFileDrop()
   {
         var lister = document.getElementById("divFileLister");
         var list = obj.GetSelectedFiles();//获取选择的文件
         for (var index = list.lbound(1); index
页: [1]
查看完整版本: FTP文件上传控件开发文档-Xproer.FtpUploader2