日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

WebForm(文件上传)

發布時間:2025/4/16 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 WebForm(文件上传) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
WebForm(文件上傳)

文件上傳控件:FileUpload

一、基本上傳

1、準備階段:(1)準備保存路徑

根目錄:string s = "Uploads/aaa.txt"; ??上傳的絕對路徑:string path = Server.MapPath(s);

2、上傳
FileUpload1.SaveAs(path);

二、優化:

1:保留文件原有的名字,防止覆蓋
解決:把路徑中的文件名替換為控件選中的文件名
string s = "Uploads/" + FileUpload1.FileName;

2、文件名一樣,會覆蓋,造成文件丟失

解決:文件名拼接時間和用戶名
string s = "Uploads/" + DateTime.Now.ToString("yyyyMMddhhmmssms") + Request.Cookies["user"].Value + FileUpload1.FileName;

3、可以上傳大文件,默認是4MB,4096KB

方法:擴容

在Web.config中的system.web標記中添加下面一句:
<httpRuntime maxRequestLength="擴容大小" />

注意:不要擴的太大,因為如果多人同時上傳大文件,可能會造成服務器內存溢出,導致服務器崩潰。

4、超過上傳要求的大小,阻止上傳并提示文件過大

服務端限制:
if (FileUpload1.PostedFile.ContentLength > 1024 * 1024 * 4)
{
Label1.Text = "文件過大!";
return;
}

客戶端限制:

<script type="text/javascript">document.getElementById("Button1").onclick = function () {var fl = document.getElementById('FileUpload1');if (fl.value.length <= 0) {document.getElementById('Label1').innerHTML = "請先選擇要上傳的文件!";return false;}else {if (fl.files[0].size > 1024 * 1024 * 4) {document.getElementById('Label1').innerHTML = "文件過大,不允許超過4MB大小!";return false;}}}</script>

上傳文件設置:

<asp:FileUpload ID="FileUpload1" accept=".jpg,.jpeg,.png" runat="server" />?

斷點續傳:

using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using System.IO; public partial class DFile : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } protected void LinBtnDFile_Click(object sender, EventArgs e) { // 創建一比特數組 byte[] buffer = new Byte[10240]; // 指定要下載文件的路徑. string filePath = @"D:\愛智旮旯.rar"; // 或取文件名包括擴展名 string fileName = Path.GetFileName(filePath); Stream fileStream = null; try { // 打開文件 fileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read); Response.Clear(); // 獲取文件的大小 long fileSize = fileStream.Length; long sum = 0; if (Request.Headers["Range"] != null) { Response.StatusCode = 206; // 表示返回到客戶端的 HTTP 輸出狀態的整數。默認值為 200。 sum = long.Parse(Request.Headers["Range"].Replace("bytes=", "").Replace("-", "")); } if (sum != 0) { Response.AddHeader("Content-Range", "bytes " + sum.ToString() + "-" + ((long)(fileSize)).ToString() + "/" + fileSize.ToString()); } // 獲取部分http頭信息 Response.AddHeader("Content-Length", ((long)(fileSize - sum)).ToString()); Response.ContentType = "application/octet-stream"; //獲取文件來源 Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(Request.ContentEncoding.GetBytes(fileName))); // Response.Flush(); fileStream.Position = sum; //設置當前流位置 fileSize = fileSize - sum; // 當文件大小大于0是進入循環 while (fileSize > 0) { // 判斷客戶端是否仍連接在服務器 if (Response.IsClientConnected) { // 獲取緩沖區中的總字節數. int length = fileStream.Read(buffer, 0, 10240); // 寫入數據 Response.OutputStream.Write(buffer, 0, length); // 將緩沖區的輸出發送到客戶端 Response.Flush(); buffer = new Byte[10240]; fileSize = fileSize - length; } else { //當用戶斷開后退出循環 fileSize = -1; } } } catch (Exception ex) { Response.Write("Error : " + ex.Message); } finally { if (fileStream != null) { //關閉文件 fileStream.Close(); } Response.End(); } } } 斷點續傳

?

posted on 2017-05-27 14:05 瀚城老爺子 閱讀(...) 評論(...) 編輯 收藏

轉載于:https://www.cnblogs.com/hclyz/p/6912147.html

總結

以上是生活随笔為你收集整理的WebForm(文件上传)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。