• HTTP文件上传插件开发文档-ASP


    版权所有 2009-2016 荆门泽优软件有限公司

    保留所有权利

    官方网站:http://www.ncmem.com/

    产品首页:http://www.ncmem.com/webplug/http-uploader2/index.asp

    在线演示:http://www.ncmem.com/products/http-uploader2/index.asp,

    开发文档:asp,jsp,php,asp.net,

    升级日志:http://www.cnblogs.com/xproer/archive/2011/03/15/1985091.html

    资源下载:cab安装包(x86),cab安装包(x64),crx安装包,crx(nat)安装,xpi安装包,exe安装包,开发文档,VC运行库,证书补丁,

    示例下载:ASP示例,ASP.NET示例,JSP示例,PHP示例,

    联系信箱:1085617561@qq.com

    联系QQ1085617561

    更新记录:

    更新时间

    描述

    2012-05-29

    更新JSP文件上传示例代码。

    2012-08-30

    增加创建文件夹和删除文件示例代码。

    2012-09-10

    增加验证本地文件是否存在的示例代码,更新创建文件夹示例代码。

    2014-03-18

    完善正式包布署章节

    增加在本地运行DEMO章节

    增加在测试服务器中运行DEMO章节

    删除测试包布署说明章节。

    新增ASP测试章节。

     

    1.      在本地运行DEMO

    1.1. ASP

    1.IIS中新建站点

    081f76af-af15-4cbb-ae25-5df259e3467c

     

    2.修改上传地址

    8cb79058-329a-4ec7-8f24-5d0885c80212

     

    2.      在测试服务器中运行DEMO

    说明:如果客户端能够正常访问互联网,则不用在测试服务器中布署控件包。

    步骤如下:

    1.将控件包(HttpUploader.cab,HttpUploader64.cab)布署在测试服务器中

         HttpUploader.cabIE(x86)浏览器控件安装包。

         HttpUploader64.cabIE(x64)浏览器控件安装包。

    2.修改up2.js中的控件包地址。

    5f8a5f56-0cea-4b5c-a8e8-8fac930001e0

     

    3.将上传地址改为测试服务器的上传地址。

    d22a79e2-5a69-4ff6-b850-6d9ce8b25d64

     

    3.      正式包布署说明

    说明:在购买后我们会以邮件方式提供控件包文件。

    1.HttpUploader.cab,HttpUploader64.cab,HttpUploader2.xpi,HttpUploader2.crx,HttpUploader2.exe上传到正式服务器中。

         HttpUploader.cabIE(x86)浏览器控件安装包。

         HttpUploader64.cabIE(x64)浏览器控件安装包。

         HttpUploader2.xpiFirefox浏览器控件安装包。

         HttpUploader2.crxChrome浏览器控件安装包。

         HttpUploader2.exe为控件集成安装包。

    2.修改up2.js文件中的配置信息。

     

    3.1. 修改版本号

    dab464b5-310b-4c8d-a51a-b8a5f25005c9

     

    3.2. 修改IE32控件Clsid

    17cd57b9-97fa-4db7-9ad6-8b0e82528c9f

     

    3.3. 修改IE32控件cab包地址

    f2040943-2153-4e13-863a-94e07e6c3aee

     

    3.4. 修改IE64控件clsid

    8561cd33-a515-476a-bc37-49a726ae7f0b

     

    3.5. 修改IE64控件cab包地址

    d489d757-39c6-46e3-982f-3518035e12e5

     

    3.6. 修改IE32IE64控件ProjID信息

    a5931373-379d-43e6-98c6-5c8c441bd05a

     

    3.7. 修改Firefox控件XpiType

    5a825ad7-789e-4ef0-b0e5-2dca38bd5e3e

     

    3.8. 修改Firefox控件xpi包地址

    9b099578-d599-47b9-ba0e-360b6a08c01f

     

    3.9. 修改chrome控件CrxTypeCrxName

    0cfb7ef6-50fc-497a-8750-d9a00ae36f21

     

    3.10. 修改Chrome控件crx包地址

    09d1861a-be00-4bce-b817-85a4e80e1f68

     

    3.11. 修改exe包地址

    b1465868-57d5-406b-b84d-ac98e7c066bf

     

     

    4.      整合到现有系统中

    主要步骤:

    1.上传js文件夹,控件包

    2.在引用页面添加js引用

    3.在引用页面编写控件初始化代码,并设置上传地址。

     

    1.上传js文件夹

    463576cc-99e7-4a6d-aa5f-9ba08e45d00d

     

    2.在引用页面添加js引用

    053fa61e-17a3-40b6-a9d5-d27248ea7e0a

     

    3.编写控件初始化代码

    4611f38b-f299-4162-a2a8-8277f35e63e3

     

    5.      自动拼接路径

    如果域名会经常变动不是固定域名,可以使用自动拼接路径函数InitPath()来简化控件布署。InitPath()函数的主要作用就是帮助开发人员拼接字符串。开发人员也可以根据自已的业务逻辑情况来修改此函数。

    以下示例演示如何使用自动拼接路径

    修改HttpUploader.js中的路径

         this.Config = {

             "EncodeType"       : "UTF-8"

             ,"CompanyLicensed" :"武汉命运科技有限公司"

             , "FileFilter"     : "*"//文件类型

             , "AppPath"        : ""//网站虚拟目录名称。子文件夹 web

             , "CabPath"        : "HttpUploader/HttpUploader.cab#version=2,4,11,45688"//CAB文件地址。使用自动拼接路径时只写CAB地址的相对路径。

             , "PostUrl"        : "upload.aspx"//文件上传路径,使用自动拼接路径时只写上传地址的相对路径

             , "ClsidDroper"    : "4D2454F8-EB25-465f-B867-C2A3E9F3D4B4"//拖拽控件

             , "ClsidUploader"  : "7AAE6FD3-C2F2-49d5-A790-1103848B3531"//文件上传控件

             , "ClsidPartition" : "6F3EB4AF-FC9C-4570-A686-88B4B427C6FE"//文件选择控件

         };

    Load函数中调用InitPath

         //在外部调用。

         this.Load = function()

         {

            this.InitPath();//自动拼接路径

        }

     

    在页面引用代码中设置AppPath

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

        var upMgr = new HttpUploaderMgr();

        upMgr.Config["AppPath"] = "/www/";//设置网站目录

         upMgr.Load();

     

         window.onload = function()

         {

             upMgr.Init();

         };

    </script>

     

    调用InitPath()后,PostUrlCabPath将会被自动拼接成下列字符串

    PostUrl = http://www.ncmem.com/upload.aspx

    CabPath = http://www.ncmem.com/HttpUploader/HttpUploader.cab#version=2,4,11,45688

     

    6.      升级控件

    一般情况下,控件升级后HttpUploader.cab会更新,同时版本号也会更新。

    主要步骤如下:

    1.      重新上传HttpUploader.cab文件。

    2.      更新HttpUploader.js中的版本号。

     

    6.1. 更新HttpUploader.js中的版本号

    Version属性为版本号。

         this.Config = {

             "EncodeType"            : "gb2312"//UTF-8,GB2312。文件名称编码方式,与web.config-requestEncoding配置对应

             , "Version"            : "2,5,53,40765"

             , "Company"            : "荆门泽优软件有限公司"

             , "License"            : ""

             , "Debug"               : false//调试开关

             , "LogFile"            : "C:\log.txt"//日志文件路径

             , "FileFilter"         : "*"//文件类型。所有类型:*。自定义类型:jpg,png,gif,bmp

             //字节计算器:http://www.beesky.com/newsite/bit_byte.htm

             //超过10MB建议选择HttpUploader6http://www.ncmem.com/webplug/http-uploader6/index.asp

             , "FileSizeLimit"       : "10485760"//允许上传的文件大小,默认10MB

             , "AllowMultiSelect"   : true//多选开关。true:开启多选。false:关闭多选

             , "CryptoType"         : "md5"//文件校验方式:md5,crc,sha1

             , "InitDir"            : ""//初始路径。示例:D:\Soft

             , "Compress"            : ""//是否开启压缩。值:zip,gzip

             , "AppPath"            : ""//网站虚拟目录名称。子文件夹 web

             , "FileFieldName"       : "file"//文件字段名称

             , "Cookie"            : ""//cookie

            , "Authenticate"       : {type:"ntlm",name:"",pass:""}//域环境信息

             , "PostUrl"            : "http://localhost:4854/asp.net/upload.aspx"

            //x86

             , "ClsidDroper"        : "4D2454F8-EB25-465f-B867-C2A3E9F3D4B4"

             , "ClsidPartition"      : "6F3EB4AF-FC9C-4570-A686-88B4B427C6FE"

             , "CabPath"            : "http://www.ncmem.com/download/HttpUploader2/HttpUploader.cab"

             //x64

             , "ClsidDroper64"       : "C9388115-887C-4d64-B175-F8F1AA5437BF"

             , "ClsidPartition64"   : "3AFFCB6D-55ED-4ada-A1EC-D7D87BA29E51"

             , "CabPath64"           : "http://www.ncmem.com/download/HttpUploader2/HttpUploader64.cab"

             //Firefox

             , "XpiType"            : "application/npHttpUp2"

             , "XpiPath"           : "http://www.ncmem.com/download/HttpUploader2/HttpUploader2.xpi"

             //Chrome

             , "CrxName"            : "npHttpUp2"

             , "CrxType"            : "application/npHttpUp2"

             , "CrxPath"           : "http://www.ncmem.com/download/HttpUploader2/HttpUploader2.crx"

             , "ExePath"            : "http://www.ncmem.com/download/HttpUploader2/HttpUploader2.exe"

             //Chrome 45

            , "NatHostName"        : "com.xproer.up2"//

             , "NatPath"            : "http://www.ncmem.com/download/HttpUploader2/HttpUploader2.nat.crx"

             , "ExePath"            : "http://www.ncmem.com/download/HttpUploader2/HttpUploader2.exe"

         };

     

    说明:

    更新版本号后,IE会自动提示用户安装最新的控件。

     

    7.      用户接口

    7.1. 配置上传地址

    方法1:在引用页面设置上传地址

    0e604198-1713-4414-b1ee-2435d1cfe75d

     

    方法2:在up2.js中设置上传地址。

    ba08da01-3447-41b4-abfd-9057892cb2e6

     

    注意:如果同时在引用页面和up2.js中配置了上传地址,那么引用页面的设置将会覆盖up2.js中的设置,即只有引用页面的设置有效。

     

    7.2. 设置服务器编码方式

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

    var fileMgr = new HttpUploaderMgr();

    fileMgr.Config["EncodeType"] = "GB2312";//设置上传编码。必须与网站配置相同。建议在HttpUploader.js中设置,这样可以在多个页面引用,而不需要再次设置。

     

    $(document).ready(function ()

    {

         fileMgr.Load();

    });

    </script>

      

    7.3. 设置文件类型

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

    var fileMgr = new HttpUploaderMgr();

    //设置允许上传的文件类型,使用英文逗号分(,)隔。如果允许所有的文件类型,则使用*

    fileMgr.Config["FileFilter"] = "jpg,png,bmp,gif,doc,pdf,txt";

     

    $(document).ready(function ()

    {

         fileMgr.Load();

    });

    </script>

     

     

    7.4. 设置附加信息

    附加信息的作用就是在上传图片的同时向服务器提交额外的字段信息。比如当用户向服务器上传截图时,服务器需要知道是哪位用户上传的截图,这时可以将用户ID添加到附加信息中,这样服务器在获取截图信息的同时也能够根据附加信息知道是哪位用户上传的截图。

    客户端:

    fileMgr.Fields["UserName"] = "test";

    服务端:

    string fname = Request.Form["UserName"];

     

    开发人员可以根据自已的业务需求来扩展附加信息:

    客户端:

    fileMgr.Fields["f1"] = "f1";

    fileMgr.Fields["f2"] = "f2";

    fileMgr.Fields["f3"] = "f3";

    fileMgr.Fields["f4"] = "f4";

    fileMgr.Fields["f5"] = "f5";

    服务端(ASP.NET)

    string f1 = Request.Form["f1"];

    string f1 = Request.Form["f2"];

    string f1 = Request.Form["f3"];

    string f1 = Request.Form["f4"];

    string f1 = Request.Form["f5"];

     

    7.5. 上传本地文件

    使用步骤如下:

    1.调用postLoc函数上传本地文件,注意路径需要使用双斜框(\)

    <div id="upPnl"></div>

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

        var fileMgr = new HttpUploaderMgr();

     

         $(document).ready(function ()

         {

             fileMgr.Load();

             fileMgr.postLoc("D:\360safe-inst.exe", "upPnl");

         });

     

    </script>

     

    7.6. 以压缩模式(zlib)上传

    说明:开启压缩后,控件上传前会对文件进行zlib压缩操作,服务端接收到的数据需要进行解压操作。压缩后传输的数据量变小,可以有效的降低网络流量从而提高上传效率。此功能特别适合企业级文件传输环境。

    deb461b0-bc12-48bb-a87e-b021e9d6b204

     

    7.7. gzip压缩模式上传

    配置方法:

    0c88003a-41b6-468a-b20b-a6d5977da1ca

    压缩效果对比:

    1.txt文件进行测试

    原文件大小:91.7kb

    提交数据:

    c96da8f0-ecc4-4644-8129-223cfc1070f5

    gzip压缩模式:

    压缩后:0.796kb

    e90d6421-6359-4df8-8773-a23d776bb2cc

     

    2.exe文件进行测试

    原文件大小:1049kb

    提交数据:

    2028f9e3-72fa-44c9-acc2-4229bf644f45

    gzip压缩模式:

    压缩后:684.820kb

    9b2a0dbb-b8e5-4966-999c-b42aa31d8896

     

    8.      UI模板

    您可以根据实际需求来修改以下模板。

     

    HTML:

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

         <div class="UploaderItemLeft">

             <div class="FileInfo">

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

                  <div name="fileSize" class="FileSize" child="1">100.23MB</div>

             </div>

             <div class="ProcessBorder top-space"><div name="process" class="Process"></div></div>

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

         </div>

         <div class="UploaderItemRight">

             <div class="BtnInfo"><span name="btnCancel" class="Btn">取消</span>&nbsp;<span name="btnDel" class="Btn hide">删除</span></div>

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

         </div>

    </div>

    9.  服务端支持

    9.1. ASP

    9.1.1. upload.asp文件

    <% @Language=vbscript Codepage=936 %>

    <%

    Option Explicit

    Response.Buffer=True

    %>

    <!--#include file="UpLoadClass.asp"-->

    <%

    dim lngUpSize,uploader,intError

         Set uploader = new UpLoadClass

         uploader.TotalSize= 10485760'10MB

         uploader.MaxSize  = 10000*1024

         uploader.FileType = "gif/jpg/png/bmp/pdf/doc/xls/rar/zip/txt"

         uploader.Savepath = "upload/"

        

         '自动创建上传文件夹

         dim folder,fs

         folder = server.MapPath(uploader.Savepath)

         set fs = Server.CreateObject("Scripting.FileSystemObject")

         if(fs.FolderExists(folder) = false) then

             fs.CreateFolder(folder)

         end if

     

         lngUpSize = uploader.Open()

         intError = uploader.Form("photo2_Err")

        

         response.Write("upload/" & uploader.Form("ServerFileName"))

         if lngUpSize>uploader.MaxSize then

    %>

             <script language="javascript">

             <!--

                  alert("您上传的文件最大不能超过10M!!");

                  history.back();

             //-->

             </script>

    <%

             response.end

         end if

         if intError=-1 then

    %>

             <script language="javascript">

             <!--

                  alert("您没有上传任何文件,请重新上传!!");

                  history.back();

             //-->

             </script>

    <%

             response.end

         end if

         Set uploader = nothing

    %>

     

  • 相关阅读:
    全面了解 NOSQL
    金融业容灾技术分析
    银行业务知识(转)
    结合工作的业务连续性实践
    金融企业架构
    window 下拉取github项目失败 (Permission denied (publickey))
    vsftpd 配置文件
    nginx下配置虚拟主机
    linux 下安装ftp 并远程连接
    find_in_set
  • 原文地址:https://www.cnblogs.com/xproer/p/5307166.html
Copyright © 2020-2023  润新知