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

版权所有 2009-2012 武汉命运科技有限公司

保留所有权利

产品博客:http://www.cnblogs.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.cnblogs.com/xproer/archive/2011/03/15/1984413.html

升级日志:http://www.cnblogs.com/xproer/archive/2011/04/04/2005251.html

资源下载:cab安装包,开发文档,示例下载,VC

联系信箱:[email protected]

联系QQ1085617561

 

1.      概述

FtpUploader2FtpUploader的基础上进行了大幅度调整和优化。

首先在FtpUploader中是使用单独的线程来计算即时上传速度的,在某些情况下计算结果可能会出现较大的误差。在FtpUploader2中我们取消了单独的速度计算线程,将速度计算与上传模块整合在一起,使速度计算更加精确。

在客户端调用方面(JavaScript)我们在COM组件中提供了一个JS对象指针,用来保存客户端的FtpUploader对象,在组件事件中将这个JS对象指针传给客户端,这样极大的简化了客户端开发模式。

在即时速度计算方面,我们取消了JS的定时调用,装饰速度计算的任务完全交给COM组件来进行。降低了线程同步访问的风险。

FtpUploader相比FtpUploader2更稳定,更高效,开发也更简单。

 

2.      快速开始

2.1.   架设FTP服务器

新颖网络FTP文件上传插件支持Microsoft FTPServ-UFileZilla

以下分别为FTP服务器的架设教程:

安装ServU—7.1http://www.cnblogs.com/xproer/archive/2010/11/20/1882370.html

安装ServU- 6.4.0 .6http://www.cnblogs.com/xproer/archive/2011/03/28/1998042.html

安装FileZilla Serverhttp://www.cnblogs.com/xproer/archive/2010/12/23/1914588.html

安装Microsoft FTP Serverhttp://www.cnblogs.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必须存在,此DIVID必须唯一。

 

方法

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"] = "4b29da 413f ";

    manager.Config["RemoteFolder"] = "upload";

 

4.      ActiveX对象

4.1.   Xproer.UploaderPartition2对象

CLSID 9463F 939-F485 -404f -9FB0-8729E82DE 11F

类型ActiveX

多文件选择对象。弹出一个文件选择对话框,为用户提供选择多个文件的功能。

方法

 

名称

说明

ShowDialog

弹出文件选择对话框

GetSelectedFiles

获取用户选择的文件列表

 

GetSelectedFiles方法

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

 

示例

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

JavaScript

<script type="text/javascript" language="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 <= list.ubound(1); index++)

         {

              if (!manager.Exist(list.getItem(index)))

              {

                   manager.AddFile(list.getItem(index));

              }

         }

         manager.PostFirst();

     }

</script>

4.2.   Xproer.FileUploader2对象

CLSID 572A 8DD8-0CAC -46c 0-A363-B3496887E3D9

类型ActiveX

文件上传对象,负责文件具体的上传和续传工作。

 

属性

 

名称

说明

FileID

文件ID。必须唯一。

LocalFile

包含完整路径的本地文件名称。例:D:\QQ.exe

RemoteFolder

远程文件夹,文件上传后在服务器端存储的位置

RemoteFile

远程文件名称。

UserName

FTP服务器用户名

UserPass

FTP服务器密码

IP

FTP服务器IP地址

Port

FTP服务器端口。默认为21

Passive

是否被动模式。默认false

 

事件

 

名称

说明

OnComplete

在文件上传完成时发生

OnPost

每当向服务器传输成功一部分数据时发生

OnError

在文件上传出现错误时发生

OnConnected

服务器连接成功

 

OnConnected事件

服务器连接成功事件。

语法:

function FtpUploader_Connected(obj)

参数:

     obj JS上传对象。

OnComplete事件

传输完成事件,当文件成功上传完毕后,系统将会调用此方法 

语法

function FtpUploader_Complete(obj)

参数:

     obj  JS上传对象。

OnPost事件

传输数据事件。每当XSUploader插件成功向服务器传输二进制数据后将触发此事件。

语法:

function FtpUploader_Process(obj, speed, postedLength, percent, time)

参数:

obj

JS上传对象。

speed

上传速度。5KB/S

postedLength

已上传大小。12.05MB

percent

已完成百分比。50%

time

剩余时间。00:02:10

OnError事件

传输错误事件,当传输出现错误时系统将会自动调用此事件。

语法:

function FtpUploader_Error(obj, errCode)

参数:

     obj JS上传对象。

     errCode 错误码。

错误码  

"0":

"启动网络环境错误"

"1":

"SOCKET错误"

"2":

"打开SOCKET错误"

"3":

"创建SOCKET错误"

"4":

"连接服务器错误"

"5":

"发送用户名错误"

"6":

"发送密码错误"

"7":

"发送数据错误"

"8":

"本地文件为空"

"9":

"远程文件为空"

"10":

"服务器IP为空"

"11":

"用户名为空"

"12":

"密码为空"

"13":

"本地文件不存在"

"14":

"不能读取本地文件"

"15":

"向本地文件写入数据失败"

"16":

"向服务器写入数据失败"

"17":

"网络命令错误"

"18":

"远程文件不存在"

"19":

"创建目录失败"

"20":

"本地文件大小超过 1G "

"21":

"用户名或密码错误"

"22":

"IP未授权"

 

示例

下面的代码将会创建一个上传项,并将本地C盘下的myfile.txt文件上传到服务端,并以myfile.txt保存。

JavaScript

var upFile = new FileUploader(1);//这里创建了一个文件上传任务,并将文件ID设置为1

upFile.ATL.UserName = "test";    //设置FTP服务器用户名

upFile.ATL.UserPass = "test";    //设置FTP服务器密码

upFile.ATL.IP = "192.168.1.1";   //设置FTP服务器IP地址

upFile.ATL.Passive = false;      //传输模式为被动模式

upFile.ATL.LocalFileName = "C:\\myfile.txt";//设置要上传的本地文件

upFile.ATL.RemoteFileName = "myfile.txt"; //设置目标文件名称

upFile.ATL.RemoteFolder = "";    //设置远程文件夹,用来存放用户上传的文件。这里默认为根目录。

//设置事件,这些事件必须设置,否则上传任务将无法执行

upFile.ATL.OnComplete = FtpUploader_Complete;

upFile.ATL.OnPost = FtpUploader_Process;

upFile.ATL.OnError = FtpUploader_Error;

upFile.ATL.OnConnected = FtpUploader_Connected;

upFile.Post(); //开始上传

4.3.   Xproer.FileDroper2对象

CLSID9FC 9422C -5C 02-4879 -889C -9C 0014EB384B

类型ActiveX

文件拖放面板,为用户提供文件的拖放功能。

 

事件

OnFileDrop事件

文件拖放事件。当用户从资源管理器向拖放面板中拖放文件时此事件将会自动被调用。

 

参数:

     arguments[0]

文件列表数组

 

示例-获取用户拖放的文件列表名称

<HTML>

<HEAD>

<TITLE>New Page</TITLE>

</HEAD>

<BODY>

<!object对象用来帮助ActiveX控件进行自动升级-->

<OBJECT ID="FilePanel1" WIDTH=192 HEIGHT=192 CLASSID="clsid: AF145FF6-EF91 -4C 91-BD85-D4ECCA224D27" DATA="DATA:application/x-oleobject;BASE64,P0yJ/coEwUiWnGww8Tau4AADAADYEwAA2BMAAA==">

</OBJECT>

<div id="divFileLister"></div>

<script language="javascript" type="text/javascript">

     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 <= list.ubound(1); ++index)

         {

              lister.innerHTML += "<p>文件名:" + list.getItem(index) + "</p>";

         }

     }

</script>

</BODY>

</HTML>

 

5.      UI模板

您可以根据需要修改此模板。

HTML:

<div class="UploaderItem" id="UploaderTemplate">

     <div class="UploaderItemLeft">

         <div class="FileName top-space">FtpUploader程序开发.pdf</div>

         <div class="ProcessBorder top-space">

              <div class="Process"></div>

         </div>

         <div class="PostInf top-space">已上传:15.3MB 速度:20KB/S 剩余时间:10:02:00</div>

     </div>

     <div class="UploaderItemRight">

         <a class="Btn" href="javascript:void(0);">取消</a>

         <div class="ProcessNum">35%</div>

     </div>

</div>

 

6.      CSS模板

CSS模型

开发者可以根据需要来修改样式。通过修改下面的样式可以自定义上传项模板的大小高度宽度和颜色。

//文件上传项模板

div.UploaderItem{font-family: 新宋体;font-size: 12px; background-color: #FFFFFF;width: 410px; height:55px; margin:5px 10px 0 20px;display:none;}

div.top-space{margin:3px 0 0 0;}

//左侧

div.UploaderItemLeft{width:370px; float:left;}

//右侧

div.UploaderItemRight{width:30px; float:left;margin:3px 0 0 0;}

//文件名称

div.UploaderItem div.FileName{font-weight: bold; overflow:hidden; width:364px;word-break: break-word; /* 文本行的任意字内断开 */

         word-wrap: break-word; /* IE */

         white-space: -moz-pre-wrap; /* Mozilla */ }

//进度条边框

div.UploaderItem div.ProcessBorder{padding: 0px;border: 1px solid #AAAAAA;width:364px;}

//进度条背景色

div.UploaderItem div.Process{ height:12px; background-color: #A5DF16;width:0;/*width:200px;*/}

//上传信息。例:已上传大小,速度,剩余时间。

div.UploaderItem div.PostInf{color: # 7A 8F 99;}

//已上传百分比

div.UploaderItem div.ProcessNum{width:30px; height:14px; line-height:14px; margin:3px 0 0 0;}

//控制按钮样式

div.UploaderItem a.Btn,div.UploaderItem a.Btn:hover{text-decoration: underline; color:#244281; height:12px;display:block;}

 

7.      应用示例

以下示例将会弹出一个对话框并将用户选定的文件上传到服务器中。

 

JavaScript:

<script type="text/javascript" language="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 <= list.ubound(1); index++)

        {

            if (!manager.Exist(list.getItem(index)))

            {

                manager.AddFile(list.getItem(index));

            }

        }

        manager.PostFirst();//开始上传队列中的第一个文件

    }

</script>

 

9.      帮助文档

9.1.   如何在文件上传成功后进行自定义操作

FileUploader插件提供了OnComplete事件,当文件上传成功后COM插件将会调用这个事件。开发人员可以在这个事件中编写自已的业务逻辑代码。

 

以下示例演示如何自定义ActiveX完成事件

var ATL = new ActiveXObject("Xproer.FtpUploader2");

ATL.OnComplete = FtpUploader_Complete;//设置事件

 

//ActiveX事件-上传完成

function FtpUploader_Complete(obj)

{

     //开发者可以在此处自定义代码

 

     CurrentFileUploader = null;

     obj.pButton.innerText = "";

     obj.pProcess.style.width = "100%";

     obj.pPercent.innerText = "100%";

     obj.pMsg.innerText = "上传完成";

     obj.State = FileUploaderState.Complete;

     obj.PostNext();

}

你可能感兴趣的:(upload)