當前位置:首頁 » 文件傳輸 » net文件上傳框架
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

net文件上傳框架

發布時間: 2022-09-01 21:00:29

A. .net實現文件上傳到伺服器

1、前端界面十分簡單,只是放一個file類型的和一個按鈕,並且為這個按鈕添加點擊事件(btnUpLoad_Click),如下圖:

protectedvoidbtnUpLoad_Click(objectsender,EventArgse)
{
//取出所選文件的本地路徑
stringfullFileName=this.UpLoad.PostedFile.FileName;
//從路徑中截取出文件名
stringfileName=fullFileName.Substring(fullFileName.LastIndexOf()+1);
//限定上傳文件的格式
stringtype=fullFileName.Substring(fullFileName.LastIndexOf(.)+1);
if(type==doc||type==docx||type==xls||type==xlsx||type==ppt||type==pptx||type==pdf||type==jpg||type==bmp||type==gif||type==png||type==txt||type==zip||type==rar)
{
//將文件保存在伺服器中根目錄下的files文件夾中
stringsaveFileName=Server.MapPath(/files)++fileName;
UpLoad.PostedFile.SaveAs(saveFileName);
Page.ClientScript.RegisterStartupScript(Page.GetType(),message,<scriptlanguage='javascript'defer>alert('文件上傳成功!');</script>);

//向資料庫存儲相應通知的附件的目錄
BLL.news.InsertAnnexBLLinsertAnnex=newBLL.news.InsertAnnexBLL();
AnnexEntityannex=newAnnexEntity();//創建附件的實體
annex.AnnexName=fileName;//附件名
annex.AnnexContent=saveFileName;//附件的存儲路徑
annex.NoticeId=noticeId;//附件所屬「通知」的ID在這里為已知
insertAnnex.InsertAnnex(annex);//將實體存入資料庫(其實就是講實體的這些屬性insert到資料庫中的過程,具體BLL層和DAL層的代碼這里不再多說)
}
else
{
Page.ClientScript.RegisterStartupScript(Page.GetType(),message,<scriptlanguage='javascript'defer>alert('請選擇正確的格式');</script>);
}
}

B. .NET 前端大文件上傳如何實現

想要想上傳大文件,必須在web.config文件中進行配置。
在<system.web>節點中添加如下代碼即可:
<httpRuntime maxRequestLength="2097151"/>
這個代碼就是表示設置最大請求值,上傳文件也就相當於請求。maxRequestLength單位為KB,最大值為:2097151.如果不設置,默認為4096 KB (4 MB)。
也就是說上傳的文件最大可以上傳2G以內的文件。
一般沒有配置的話,默認只能上傳4M以內的文件。配置了的話就可以上傳更大的文件。

C. 如何用asp.net實現文件上傳的代碼

#region 文件上傳

string path = null;
string name = null;
string type2 = null;
string upfile = null;
if (fu.HasFile)
{
try
{
name = fu.FileName;
type2 = name.Substring(name.LastIndexOf(".") + 1);
upfile = System.DateTime.Now.ToString("yyyyMMddhhmmss") + "." + type2;
if (type2.ToLower() == "rar" || type2.ToLower() == "zip" || type2.ToLower() == "doc" || type2.ToLower() == "xls" || type2.ToLower() == "ppt")
{
path = Server.MapPath("file") + "\\";
if (!File.Exists(path))
{
Directory.CreateDirectory(path);
fu.SaveAs(path + name);
}
fu.SaveAs(path + name);
}
else
{
Response.Write("<script>alert('格式不正確(格式(.doc,.xls,.rar,.zip,.ppt)!');</script>");
Response.End();
}
}
catch(Exception ex)
{
Response.Write("<script>alert('上傳格式錯誤:" + ex.Message.ToString() + "');window.location.href='Upload.aspx';</script>");
}
}
else
{
upfile = "N/A";
name="N/A";

}
if (upfile != "N/A" || name!="N/A")
{
UpLoad up = new UpLoad();
UpLoadBll uBll = new UpLoadBll();
up.setFileName(upfile);
up.setU_name(name);
if (uBll.insertFile(up))
{
Response.Write("<script>alert('" + uBll.getMsg() + "');window.location.href='Upload.aspx';</script>");
}
else
{
Response.Write("<script>alert('" + uBll.getMsg() + "');window.location.href='Upload.aspx';</script>");
}

}
else
{
Response.Write("<script>alert('上傳文件的內容或上傳文件不能為空!');window.location.href='Upload.aspx';</script>");

}
}
#endregion

然後把upfile 插入到資料庫就OK了

D. 求C#.NET上傳大文件的三種解決方案

HTML部分

<%@PageLanguage="C#"AutoEventWireup="true"CodeBehind="index.aspx.cs"Inherits="up6.index"%>

<!DOCTYPEhtmlPUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type"content="text/html; charset=gb2312"/>

<title>up6-多標簽演示頁面</title>

<linkhref="js/up6.css"type="text/css"rel="Stylesheet"charset="gb2312"/>

<scripttype="text/javascript"src="js/jquery-1.4.min.js"></script>

<scripttype="text/javascript"src="js/json2.min.js"charset="utf-8"></script>

<scripttype="text/javascript"src="js/up6.config.js"charset="utf-8"></script>

<scripttype="text/javascript"src="js/up6.app.js"charset="utf-8"></script>

<scripttype="text/javascript"src="js/up6.edge.js"charset="utf-8"></script>

<scripttype="text/javascript"src="js/up6.file.js"charset="utf-8"></script>

<scripttype="text/javascript"src="js/up6.folder.js"charset="utf-8"></script>

<scripttype="text/javascript"src="js/up6.js"charset="utf-8"></script>

<scriptlanguage="javascript"type="text/javascript">

varcbMgr =newHttpUploaderMgr();

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() {

varpath = $("#filePath").val();

cbMgr.app.addFile({ pathLoc: path });

});

//上傳指定目錄

$("#btnUpFd").click(function() {

varpath = $("#folderPath").val();

cbMgr.app.addFolder({ pathLoc: path });

});

});

</script>

</head>

<body>

<p>up6多標簽上傳演示頁面</p>

<p><ahref="db/clear.aspx"target="_blank">清空資料庫</a></p>

<p><ahref="filemgr/index.aspx"target="_blank">文件管理器演示</a></p>

<p><ahref="index2.aspx"target="_blank">單面板演示</a></p>

<p><ahref="down2/index.htm"target="_blank">打開下載頁面</a></p>

<p><ahref="index-single.htm"target="_blank">單文件上傳演示</a></p>

<p>

文件路徑:<inputid="filePath"type="text"size="50"value="D:\360safe-inst.exe"/>&nbsp;

<inputid="btnUpF"type="button"value="上傳本地文件"/>

</p>

<p>

目錄路徑:<inputid="folderPath"type="text"size="50"value="C:\Users\Administrator\Desktop\test"/>&nbsp;

<inputid="btnUpFd"type="button"value="上傳本地目錄"/>

</p>

<divid="FilePanel"></div>

<divid="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的摘要說明。

///實現多文件上傳

/// </summary>

publicclass Upload: System.Web.UI.Page

{

protected System.Web.UI.WebControls.Button UploadButton;

protected System.Web.UI.WebControls.Label strStatus;

privatevoid Page_Load(object sender, System.EventArgs e)

{

///在此處放置用戶代碼以初始化頁面

if(this.IsPostBack)this.SaveImages();

}

private Boolean SaveImages()

{

///'遍歷File表單元素

HttpFileCollection files= HttpContext.Current.Request.Files;

/// '狀態信息

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>");

///'可根據擴展名字的不同保存到不同的文件夾

///注意:可能要修改你的文件夾的匿名寫入許可權。

postedFile.SaveAs(System.Web.HttpContext.Current.Request.MapPath("images/")+ fileName);

}

}

strStatus.Text= strMsg.ToString();

returntrue;

}

catch(System.Exception Ex)

{

strStatus.Text= Ex.Message;

returnfalse;

}

}

#region Web窗體設計器生成的代碼

overrideprotectedvoid OnInit(EventArgs e)

{

//

// CODEGEN:該調用是 ASP.NET Web 窗體設計器所必需的。

//

InitializeComponent();

base.OnInit(e);

}

/// <summary>

///設計器支持所需的方法 - 不要使用代碼編輯器修改

///此方法的內容。

/// </summary>

privatevoid InitializeComponent()

{

this.ID="Upload";

this.Load+=new System.EventHandler(this.Page_Load);

}

#endregion

}

}

選擇文件夾

後端代碼邏輯大部分是相同的

E. 現在主流的第三方.net文件上傳組件有哪些

你們項目是什麼需求?如果是普通文件上傳的話,
就用自帶的,如果是小文件批量上傳可以用Flash的,
如果是大文件上傳的話,可以用HTTP斷點續傳控制項,比如HttpUploader5