最近项目使用了Uploadify一个上传插件,感觉的挺好用的。

上传控件:

引用JS

<script src='<% =ResolveUrl("~/JS/Uploadify/jquery.uploadify.js")%>' type="text/javascript"></script>

插件使用方法:

function UploadFY() {

var upload = {

'swf': '../JS/Uploadify/uploadify.swf',

'uploader': '../Ashx/FileOpHandler.ashx?Op=UploadFile&KGuid=' + Kguid + '&dType=SHPY_Files',

'buttonImg': '<% =ResolveUrl("~/JS/Uploadify/licon_001.gif")%>',

'cancelImg': '<% =ResolveUrl("~/JS/Uploadify/cancel.png")%>',

'queueID': Kguid,

'auto': true,

'multi': true,

'height': 22,

'width': 70,

'buttonText': '',

'fileTypeDesc': '系统支持文件',        // The description for file types in the browse dialog

'fileTypeExts': '*.doc;*.docx;*.xls;*.xlsx;*.pdf;*.rar;*.gd',

//需要重写的事件

'overrideEvents': ['onSelectError', 'onDialogClose'],

'multi': false,      //是否允许多选

'auto': true,       //是否允许自动上传

'method': 'GET',

'queueSizeLimit': 300,      //同时上传数量

'uploadLimit': 10000,        //一次浏览器课上成总数量

'fileSizeLimit': '10MB',   //单个文件大小设置

'sizeLimit': 4000000,

'onQueueComplete': function (file) {         //所有文件上传完成时触发此事件

},

'onSelect': function (file) {

//$('#fileupload').uploadifySettings('formData', { 'ASPSESSID': ASPSESSID, 'AUTHID': auth });

//alert(formDate);

fileName = file.name;

},

//返回一个错误,选择文件的时候触发

'onSelectError': function (file, errorCode, errorMsg) {

switch (errorCode) {

case -100:

alert("上传的文件数量已经超出系统限制的" + $('#fileupload').uploadify('settings', 'queueSizeLimit') + "个文件!");

return;

case -110:

alert("文件 [" + file.name + "] 大小超出系统限制的10MB大小!");

//  alert("文件 [" + file.name + "] 大小超出系统限制的" + $('#fileupload').uploadify('settings', 'fileSizeLimit') + "大小!");

return;

case -120:

alert("文件 [" + file.name + "] 大小超出系统限制的10MB大小!");

return;

case -130:

alert("文件 [" + file.name + "] 类型不正确!");

return;

default:

alert("文件 [" + file.name + "] 文件检查发生错误!");

return;

}

},

//检测FLASH失败调用

'onFallback': function () {

alert("您未安装FLASH控件,无法上传图片!请安装FLASH控件后再试。");

},

'width': 34, //文件选择按钮大小

'height': 22,

'removeCompleted': true,

'removeTimeout': 0.1,    //上传完成后自动消失时间/秒

'onQueueComplete': function (file) {         //所有文件上传完成时触发此事件

if (fileName.length > 100) {

alert("文件名过长!");

return;

}

$("#hdAttachmentName").val(fileName);

$("#hdAttachmentPath").val('/uploads/SHPY_Files' + '/' + Kguid + '/' + fileName);

$("#<%=DivFileLink.ClientID %>").html('<a href="javascript:void(0)" onclick="Down()" >' + fileName + '</a>&nbsp;&nbsp;<img src="../JS/Uploadify/cancel.png" align="middle"  onclick=DeleteFile() />');

}

}

return upload;

}

function LoadUpload() {

$("input[type='file']").each(function () {

$(this).uploadify((UploadFY()))

});

}

function Down() {

document.getElementById('btnDown').click();

}

function DeleteFile() {

$("#hdAttachmentName").val('');

$("#hdAttachmentPath").val('');

$("#<%=DivFileLink.ClientID %>").html('');

//此处可写触发删除文件

}

页面加载的时候调用:

LoadUpload();

FileOpHandler.ashx

上传代码:

private void UploadFile(HttpContext context)

{

try

{

HttpPostedFile file = context.Request.Files["Filedata"];

string KGuid = q(context, "KGuid");

string FileName = file.FileName;

int FileLength = file.ContentLength; ;

string FileType = file.FileName.Substring(file.FileName.LastIndexOf("."));

string CreateUserName = q(context, "CreateUserName");

string CreateUserID = q(context, "CreateUserID");

DateTime CreateDateTime = DateTime.Now;

string uploadPath = context.Server.MapPath("..\\uploads\\" + q(context, "dType") + "\\" + KGuid + "\\");

string FilePath = "..\\uploads\\" + q(context, "dType") + "\\" + KGuid + "\\" + FileName;

if (file != null)

{

if (!Directory.Exists(uploadPath))

{

Directory.CreateDirectory(uploadPath);

}

file.SaveAs(uploadPath + file.FileName);

//生成缩略图

}

context.Response.Write("1");

}

catch

{

context.Response.Write("0");

}

}

private string q(HttpContext context, string str)

{

if (context.Request[str] != null)

return context.Request[str].ToString();

return "";

}

public bool success

{

get;

set;

}

/// <summary>

/// Gets or sets the MSG.

/// </summary>

/// <value>The MSG.</value>

public string msg

{

get;

set;

}

/// <summary>

/// Gets or sets the public key.

/// </summary>

/// <value>The public key.</value>

public object data

{

get;

set;

}

文件下载:

protected void btnDown_Click(object sender, EventArgs e)

{

string filePath = Server.MapPath("../" + hdAttachmentPath.Value);

try

{

FileInfo info = new FileInfo(filePath);

if (!info.Exists)

{

Page.ClientScript.RegisterStartupScript(this.GetType(), "message", "$.messager.alert('消息提示', '文件不存在!', 'info');", true);

return;

}

long fileSize = info.Length;

Response.Clear();

Response.ContentType = "application/x-zip-compressed";

Response.AddHeader("Content-Disposition", "attachment;filename=" +HttpUtility.UrlEncode( info.Name));

//不指明Content-Length用Flush的话不会显示下载进度

Response.AddHeader("Content-Length", fileSize.ToString());

Response.TransmitFile(filePath, 0, fileSize);

Response.Flush();

Response.Close();

}

catch (Exception ex)

{

Page.ClientScript.RegisterStartupScript(this.GetType(), "message", "$.messager.alert('消息提示', " + ex.Message + ", 'info');", true);

}

}

Uploadify使用随笔的更多相关文章

  1. 基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用

    大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用>中可以看到,Asp.NET中 ...

  2. uploadify.js

    基于uploadify.js实现多文件上传和上传进度条的显示 uploadify是JQuery的一个插件,主要实现文件的异步上传功能,可以自定义文件大小限制.文件类型.是否自动上传等属性,可以显示上传 ...

  3. 上传组件uploadify的使用

    上传组件uploadify的使用 大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用& ...

  4. 基于MVC4+EasyUI的Web开发框架形成之旅(4)--附件上传组件uploadify的使用

    大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用>中可以看到,Asp.NET中 ...

  5. asp.net(c#)开发中的文件上传组件uploadify的使用方法(带进度条)

    上文件传很常见,现在就文件上传利用HTML的File控件(uploadify)的,这里为大家介绍一下(uploadify)的一些使用方法.在目前Web开发中用的比较多的,可能uploadify(参考h ...

  6. (转)基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用

    http://www.cnblogs.com/wuhuacong/p/3343967.html 大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随 ...

  7. ASP.NET Uploadify 上传文件过大报错

    Uploadify上传文件原来很早之前用过,没发现什么问题.今天再使用过程中,当文件大于30M的时候就会报错404.查看错误消息提示配置最大上传太小了.需要修改. 记得原来配置上传文件大小在这里:&l ...

  8. ASP.NET Uploadify 上传文件过大 报错(http error)借鉴,以防忘记

    Uploadify上传文件原来很早之前用过,没发现什么问题.今天再使用过程中,当文件大于30M的时候就会报错404.查看错误消息提示配置最大上传太小了.需要修改. 记得原来配置上传文件大小在这里:&l ...

  9. jquery.uploadify文件上传组件

    1.jquery.uploadify简介 在ASP.NET中上传的控件有很多,比如.NET自带的FileUpload,以及SWFUpload,Uploadify等等,尤其后面两个控件的用户体验比较好, ...

随机推荐

  1. 工作中最常用的Excel函数公式大全

    电脑那些事儿2016-05-18 22:23:02微软 公式 工作阅读(22574)评论(1) 声明:本文由入驻搜狐公众平台的作者撰写,除搜狐官方账号外,观点仅代表作者本人,不代表搜狐立场.举报 Wo ...

  2. H5手机端关注的问题

    手机端页面写css时应该注意的问题: 设备的屏幕尺寸   设备的分辨率   用户的操作习惯以及点击区域的大小   移动端浏览器的特性   鉴于分辨率等情况而引出的图片尺寸.布局方式等诸多细节问题   ...

  3. RDLC中添加参数,用来显示报表中数据集之外的信息。

    我添加了两个参数,首先后台: ReportParameter rp = ,,).ToString()); ReportParameter rp1 = new ReportParameter(" ...

  4. class命名

    常见class关键词: 布局类:header, footer, container, main, content, aside, page, section 包裹类:wrap, inner 区块类:r ...

  5. VMware Workstation 10+Centos7(64位)共享文件夹

    这一两天一直在研究VMware Workstation自带的共享文件夹的功能,期间出了不少问题,在公司搭建的是vm10.0+centos07,在家搭建的是VM 7+centos07... 公司环境搭建 ...

  6. linux下tomcat的shutdown命令杀不死进程

    tomcat在windows下可以直接关闭,但是貌似在Linux下有时候shutdown.sh 没有关闭tomcat进程:国庆前最后一天没事,解决你~~~~ 现象: 在Linux下shutdown.s ...

  7. 重温Javascript第一章

    一.script标签 script标签有6个属性,其中一个废弃,五个可选. 按照传统的写法,<script>的标签都是放在<head>元素中,但是在<head>中包 ...

  8. VPN安装后报错:Reason442 & Error56

    VPN安装后一直报错,同样的32位安装包别人安装是正常,自己安装就不正常了,考虑到是自己电脑配置的问题. 经过一番努力,解决了问题,下面就本次解决过程做一个小小的总结. (1)确保VPN Servic ...

  9. RHEL 6.0服务器安装Oracle 11G R2 最终版

    RHEL6安装Oracle 11g R2最终版 结合网上教程 服务器实战所得 1.使用DVD做yum源新建dvd挂载目录[root@fxq-dp ~]# mkdir /media/iso进入到DVD挂 ...

  10. 解决Gradle生成Eclipse支持后,发布到Tomcat丢失依赖jar包的问题

    最近一个项目中,使用号称下一代构建工具的Gradle构建项目. 使用中发现一个问题,Gradle从中央库下载的jar文件在系统的其它目录,使用gradle eclipse添加Eclipse支持时,ja ...