C#.net大文件上傳解決方案支持分片斷點上傳
當(dāng)前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
HTML部分 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="index.aspx.cs" Inherits="up6.index" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>up6-多標(biāo)簽演示頁面</title> <link href="js/up6.css" type="text/css" rel="Stylesheet" charset="gb2312"/> <script type="text/javascript" src="js/jquery-1.4.min.js"></script> <script type="text/javascript" src="js/json2.min.js" charset="utf-8"></script> <script type="text/javascript" src="js/up6.config.js" charset="utf-8"></script> <script type="text/javascript" src="js/up6.app.js" charset="utf-8"></script> <script type="text/javascript" src="js/up6.edge.js" charset="utf-8"></script> <script type="text/javascript" src="js/up6.file.js" charset="utf-8"></script> <script type="text/javascript" src="js/up6.folder.js" charset="utf-8"></script> <script type="text/javascript" src="js/up6.js" charset="utf-8"></script> <script language="javascript" type="text/javascript"> var cbMgr = new HttpUploaderMgr(); cbMgr.event.md5Complete = function (obj, md5) { /*alert(md5);*/ }; cbMgr.event.fileComplete = function (obj) { /*alert(obj.fileSvr.pathSvr);*/ }; cbMgr.event.queueComplete = function () { $(document.body).append("隊列完成<br/>"); } cbMgr.event.addFdError = function (jv) { alert("本地路徑不存在:" + jv.path); }; cbMgr.event.scanComplete = function (obj) { /*alert(obj.folderSvr.pathLoc);*/ }; cbMgr.Config["Cookie"] = 'ASP.NET_SessionId=<%=Session.SessionID%>'; cbMgr.Config.Fields["uid"] = 0;
$(function () { cbMgr.load_to("FilePanel"); //上傳指定文件 $("#btnUpF").click(function () { var path = $("#filePath").val(); cbMgr.app.addFile({ pathLoc: path }); }); //上傳指定目錄 $("#btnUpFd").click(function () { var path = $("#folderPath").val(); cbMgr.app.addFolder({ pathLoc: path }); }); }); </script> </head> <body> <p>up6多標(biāo)簽上傳演示頁面</p> <p><a href="db/clear.aspx" target="_blank">清空數(shù)據(jù)庫</a></p> <p><a href="filemgr/index.aspx" target="_blank">文件管理器演示</a></p> <p><a href="index2.aspx" target="_blank">單面板演示</a></p> <p><a href="down2/index.htm" target="_blank">打開下載頁面</a></p> <p><a href="index-single.htm" target="_blank">單文件上傳演示</a></p> <p> 文件路徑:<input id="filePath" type="text" size="50" value="D:\\360safe-inst.exe" /> <input id="btnUpF" type="button" value="上傳本地文件" /> </p> <p> 目錄路徑:<input id="folderPath" type="text" size="50" value="C:\\Users\\Administrator\\Desktop\\test" /> <input id="btnUpFd" type="button" value="上傳本地目錄" /> </p> <div id="FilePanel"></div> <div id="msg"></div> </body> </html>
代碼部分 using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Drawing; using System.Web; using System.Web.SessionState; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.HtmlControls;
namespace WebPortal { /// <summary> /// UpLoad 的摘要說明。 /// 實現(xiàn)多文件上傳 /// </summary> public class Upload : System.Web.UI.Page { protected System.Web.UI.WebControls.Button UploadButton; protected System.Web.UI.WebControls.Label strStatus;
private void Page_Load(object sender, System.EventArgs e) { /// 在此處放置用戶代碼以初始化頁面 if (this.IsPostBack) this.SaveImages(); }
private Boolean SaveImages() { ///'遍歷File表單元素 HttpFileCollection files = HttpContext.Current.Request.Files;
/// '狀態(tài)信息 System.Text.StringBuilder strMsg = new System.Text.StringBuilder(); strMsg.Append("上傳的文件分別是:<hr color=red>"); try { for(int iFile = 0; iFile < files.Count; iFile++) { ///'檢查文件擴展名字 HttpPostedFile postedFile = files[iFile]; string fileName, fileExtension; fileName = System.IO.Path.GetFileName(postedFile.FileName); if (fileName != "") { fileExtension = System.IO.Path.GetExtension(fileName); strMsg.Append("上傳的文件類型:" + postedFile.ContentType.ToString() + "<br>"); strMsg.Append("客戶端文件地址:" + postedFile.FileName + "<br>"); strMsg.Append("上傳文件的文件名:" + fileName + "<br>"); strMsg.Append("上傳文件的擴展名:" + fileExtension + "<br><hr>"); ///'可根據(jù)擴展名字的不同保存到不同的文件夾 ///注意:可能要修改你的文件夾的匿名寫入權(quán)限。 postedFile.SaveAs(System.Web.HttpContext.Current.Request.MapPath("images/") + fileName); } } strStatus.Text = strMsg.ToString(); return true; } catch(System.Exception Ex) { strStatus.Text = Ex.Message; return false; } } #region Web 窗體設(shè)計器生成的代碼 override protected void OnInit(EventArgs e) { // // CODEGEN: 該調(diào)用是 ASP.NET Web 窗體設(shè)計器所必需的。 // InitializeComponent(); base.OnInit(e); }
/// <summary> /// 設(shè)計器支持所需的方法 - 不要使用代碼編輯器修改 /// 此方法的內(nèi)容。 /// </summary> private void InitializeComponent() { this.ID = "Upload"; this.Load += new System.EventHandler(this.Page_Load);
} #endregion } }
選擇文件夾
js部分 后端代碼邏輯大部分是相同的,目前能夠支持MySQL,Oracle,SQL。在使用前需要配置一下數(shù)據(jù)庫,可以參考我寫的這篇文章:http://blog.ncmem.com/wordpress/2019/08/07/java超大文件上傳與下載/ 該文章在 2021/1/29 22:02:20 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |