一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - ASP.NET文件上傳Upload的實現方法

ASP.NET文件上傳Upload的實現方法

2020-03-28 13:12???笨小孩 ASP.NET教程

這篇文章主要為大家詳細介紹了ASP.NET文件上傳的實現方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了ASP.NET 文件上傳,供大家參考,具體內容如下

1、最近應項目開發的需求要實現附件的異步上傳和下載。

2、上傳:文件上傳到指定的路徑下,并返回上傳文件的信息給前端界面,如:文件的圖標、上傳的文件名、文件的大小。

3、上傳后,在前端界面上顯示上傳的文件信息,點擊文件名實現將上傳的文件下載到本地。

4、先展示一下Demo運行的效果圖:

ASP.NET文件上傳Upload的實現方法

點擊提交后:

ASP.NET文件上傳Upload的實現方法

點擊文件名實現下載到本地:

ASP.NET文件上傳Upload的實現方法

5、下面就給出前臺代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<!DOCTYPE html>
<html>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>Ajax Form - jQuery EasyUI Demo</title>
 <link rel="stylesheet" type="text/css" href="http://www.jeasyui.com/easyui/themes/default/easyui.css">
 <link rel="stylesheet" type="text/css" href="http://www.jeasyui.com/easyui/themes/icon.css">
 <link rel="stylesheet" type="text/css" href="http://www.jeasyui.com/easyui/demo/demo.css">
 <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.1.min.js"></script>
 <script type="text/javascript" src="http://www.jeasyui.com/easyui/jquery.easyui.min.js"></script>
</head>
<body>
 <h2>Ajax Form Demo</h2>
 <div class="demo-info" style="margin-bottom:10px">
 <div class="demo-tip icon-tip"> </div>
 <div>Type in input box and submit the form.</div>
 </div>
 
 <div class="easyui-panel" title="Ajax Form" style="width:300px;padding:10px;">
 <form id="ff" action="api/Loding" method="post" enctype="multipart/form-data">
  <table>
  <tr>
   <td>Name:</td>
   <td><input name="name" class="f1 easyui-textbox"></input></td>
  </tr>
  <tr>
   <td>Email:</td>
   <td><input name="email" class="f1 easyui-textbox"></input></td>
  </tr>
  <tr>
   <td>Phone:</td>
   <td><input name="phone" class="f1 easyui-textbox"></input></td>
  </tr>
  <tr>
   <td>File:</td>
   <td><input name="file" class="f1 easyui-filebox"></input></td>
  </tr>
  <tr>
   <td></td>
   <td><input type="submit" value="提交"></input></td>
  </tr>
  </table>
  <input type="text" value="LodingTable" name="tableName" hidden="hidden" />
 </form>
 </div>
 <div>
 <img id="img" src="" width="20" height="20" />
 <a id="downLoad" downloadid="0" href="#"></a>
 <label>文件大小:</label>
 <label class="size"></label><button id="delete">刪除</button>
 <button id="loding">導入1</button>
 </div>
 <style scoped>
 .f1 {
  width: 200px;
 }
 </style>
 <script type="text/javascript">
 $(function () {
  $("#loding").hide();
  $("#delete").hide().click(function () {
  alert("刪除文件");
  });
  $("#loding").click(function () {
  var tUrl = '/api/Loding/Get';
  //var tJsonStr = '{"idInventoryPrice":"4","withdrawDetails":[{"cInvCode":"800487","cInvCodeSub":"00","iConverDiscount":"0","iUnitPrice":"9.9","iSalePrice":"9.9"},{"cInvCode":"800689","cInvCodeSub":"00","iConverDiscount":"0","iUnitPrice":"6.5","iSalePrice":"5.9"}]}';
  $.ajax({
   type: "Get",
   url: tUrl,
   dataType: "json",
   async: false,
   success: function (data) {
   alert(JSON.stringify(data));
   }
  });
  });
  $('#ff').form({
  success: function (data) {
   var json = JSON.parse(data);
   if (json.result == 1) {
   $("#delete").show();
   $("#img").attr("src", json.details[0].AttachmentNameTypeICO);
   $("#downLoad").attr("downloadid", json.details[0].ID);   $("#downLoad").html(json.details[0].AttachmentName);
   $(".size").html(json.details[0].AttachSize + "KB");
   var tUrl = 'http://localhost:11703/api/Loding/DownLoad?ID=' + $("#downLoad").attr("downloadid");
   $("#downLoad").attr("href", tUrl);
   }
   else {
   alert(json.resultdetail);
   }
  }
  });
 });
 </script>
</body>
</html>

6、后臺上傳代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
NameValueCollection nvf = HttpContext.Current.Request.Form;
  if (!Request.Content.IsMimeMultipartContent())
  {
  throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
  }
  string tempPath = "/Upload/" + DateTime.Now.ToString("yyyy-MM-dd/");
  string fileSaveLocation = HttpContext.Current.Server.MapPath("~" + tempPath);//附件的保存地址
  Dictionary<string, object> dic = new Dictionary<string, object>();
  if (!Directory.Exists(fileSaveLocation))
  {
  Directory.CreateDirectory(fileSaveLocation);
  }
  CustomMultipartFormDataStreamProvider provider = new CustomMultipartFormDataStreamProvider(fileSaveLocation);
  try
  {
  var result = await Request.Content.ReadAsMultipartAsync(provider).ContinueWith<Dictionary<string, object>>(x =>
  {
   var file = provider.FileData[0];
   FileInfo fileinfo = new FileInfo(file.LocalFileName);
   if (fileinfo.Length <= 0)
   {
   dic.Add("result", -1);
   dic.Add("resultdetail", "未上傳文件");
   }
   else
   {
   double? filelength = fileinfo.Length / 1024.0;
   if (filelength > 10 * 1024)
   {
    dic.Add("result", -1);
    dic.Add("resultdetail", "上傳文件不能大于10M");
   }
   else
   {
    string saveFileName = Guid.NewGuid().ToString() + fileinfo.Extension;
    fileinfo.CopyTo(Path.Combine(fileSaveLocation, saveFileName), true);
    fileinfo.Delete();
    dic.Add("result", 1);
    dic.Add("resultdetail", "上傳成功");
    dic.Add("realPath", file.LocalFileName);//附件保存的絕對路徑
    dic.Add("attachmentType", fileinfo.Extension);//附件類型
    dic.Add("attachmentName", Path.GetFileName(file.LocalFileName));//上傳的附件名
    dic.Add("attachSize", Convert.ToInt32(filelength));//附件大小KB
    dic.Add("aealPath", tempPath + saveFileName);//附件保存相對路徑
   }
   }
   return dic;
  }, TaskScheduler.FromCurrentSynchronizationContext());
  }
  catch (Exception ex)
  {
  return HandleJson.ToJson(ex.ToString(), false);
  }
  var isSuccess = dic["result"].TryToInt() == 1;
  var msg = dic["resultdetail"].TryToString();//返回上傳信息
  var realPath = string.Empty;//附件保存的絕對路徑
  var relativePath = string.Empty;//返回相對路徑
  var AttachSize = 0;//文件大小kB
  var AttachmentType = string.Empty;//文件擴展名
  var AttachmentName = string.Empty;//原文件名
  if (isSuccess)
  {
  realPath = dic["realPath"].TryToString();
  relativePath = dic["aealPath"].TryToString();
  AttachSize = dic["attachSize"].TryToInt();
  AttachmentType = dic["attachmentType"].TryToString();
  AttachmentName = dic["attachmentName"].TryToString();
  }
 
  StringBuilder sql = new StringBuilder();
  if (isSuccess)
  {
  try
  {
   #region 獲取圖標路徑
 
   var ICOPath = string.Empty;
   sql.Append(@"SELECT * FROM dbo.AttachmentType(NOLOCK) WHERE AttachmentType=@AttachmentType");
   var ICOTable = Common.HandleSQL.GetData(sql.ToString(), null, new SqlParameter[] { new SqlParameter("@AttachmentType", AttachmentType) });
   if (ICOTable.Rows.Count <= 0)
   {
   ICOPath = "";
   }
   else
   {
   ICOPath = ICOTable.Rows[0]["AttachmentNameTypeICO"].ToString();
   }
 
   #endregion 獲取圖標路徑
 
   #region 保存上傳記錄
 
   sql.Clear();
   sql.Append(@"DECLARE @ID INT
SELECT @ID=MAX(ID)+1 FROM dbo.Attachment(NOLOCK)
IF(@ID IS NULL)
BEGIN
SET @ID=1
END
INSERT INTO dbo.Attachment
 ( ID ,
  AttachmentName ,
  AttachmentType ,
  RealPath ,
  AttachSize ,
  UpLoadDate ,
  UpLoadPerson ,
  UpLoadIPAddress
 )
VALUES ( @ID , -- ID - int
  @AttachmentName , -- AttachmentName - nvarchar(max)
  @AttachmentType , -- AttachmentType - nvarchar(50)
  @RealPath , -- RealPath - nvarchar(max)
  @AttachSize , -- AttachSize - bigint
  GETDATE() , -- UpLoadDate - datetime
  @UpLoadPerson , -- UpLoadPerson - nvarchar(50)
  @UpLoadIPAddress -- UpLoadIPAddress - varchar(50)
 )
SELECT * FROM dbo.Attachment(NOLOCK) WHERE ID=@ID;
");
   SqlParameter[] paras = new SqlParameter[] { new SqlParameter("@AttachmentName", AttachmentName),
   new SqlParameter("@AttachSize", AttachSize), new SqlParameter("@RealPath", relativePath),
   new SqlParameter("@AttachmentType", AttachmentType),new SqlParameter("@UpLoadPerson","魏小偉"),new SqlParameter("@UpLoadIPAddress",HandleLog.getIPAddress()) };
   var insert = GetData(sql.ToString(), null, paras);
   insert.Columns.Add("AttachmentNameTypeICO", typeof(string));
   insert.Rows[0]["AttachmentNameTypeICO"] = ICOPath;
   int ID = Convert.ToInt32(insert.Rows[0]["ID"].ToString());//上傳附件的ID
   return HandleJson.ToJson(insert, 0);
 
   #endregion 保存上傳記錄
  }
  catch (Exception ex)
  {
   if (System.IO.File.Exists(realPath))
   {
   File.Delete(realPath);
   }
   return HandleJson.ToJson(ex.ToString(), false);
  }
  }
  else
  {
  return HandleJson.ToJson(msg, false);
  }

7、下載代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
[HttpGet, Route("api/Loding/DownLoad")]
 public HttpResponseMessage DownLoad()
 {
  #region 獲取界面參數
 
  NameValueCollection nvc = HttpContext.Current.Request.QueryString;
  int ID = nvc["ID"].TryToInt();
  if (ID <= 0)
  {
  return HandleJson.ToJson("傳入參數錯誤", false);
  }
 
  #endregion 獲取界面參數
 
  #region SQL
 
  StringBuilder sql = new StringBuilder();
  sql.Append(@"SELECT * FROM dbo.Attachment(NOLOCK) WHERE ID=@ID ");
 
  #endregion SQL
 
  #region 執行SQL
 
  var dt = HandleSQL.GetData(sql.ToString(), null, new SqlParameter[] { new SqlParameter("@ID", ID) });
  if (dt.Rows.Count <= 0)
  {
  return HandleJson.ToJson("未找到下載文件", false);
  }
  var filePath = HttpContext.Current.Server.MapPath("~" + dt.Rows[0]["RealPath"].TryToString());//下載文件的絕對路徑
  string fileName = dt.Rows[0]["AttachmentName"].TryToString();//下載的文件名
 
  #endregion 執行SQL
 
  #region 下載文件并添加下載記錄
 
  try
  {
  //var FilePath = System.Web.Hosting.HostingEnvironment.MapPath(@"~/download/" + fileName);
  var stream = new FileStream(filePath, FileMode.Open);
  HttpResponseMessage response = new HttpResponseMessage(HttpStatusCode.OK);
  response.Content = new StreamContent(stream);
  response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
  response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment")
  {
   FileName = fileName
  };
 
  #region 添加下載記錄
 
  sql.Clear();
  SqlParameter[] paras = new SqlParameter[] { new SqlParameter("@ID", ID), new SqlParameter("@DownLoadPerson", "魏小偉"), new SqlParameter("@DownLoadIP", HandleLog.getIPAddress()) };
  sql.Append(@"DECLARE @AutoID INT
SELECT @AutoID=MAX(AutoID)+1 FROM dbo.AttachmentDowLoadLog(NOLOCK)
IF(@AutoID IS NULL)
BEGIN
SET @AutoID=1
END
INSERT INTO dbo.AttachmentDowLoadLog
 ( AutoID ,
  ID ,
  DownLoadPerson ,
  DownLoadDate ,
  DownLoadIP
 )
VALUES ( @AutoID , -- AutoID - int
  @ID , -- ID - int
  @DownLoadPerson , -- DownLoadPerson - nvarchar(max)
  GETDATE() , -- DownLoadDate - datetime
  @DownLoadIP -- DownLoadIP - nvarchar(50)
 );");
  execSQL(sql.ToString(), null, paras);
 
  #endregion 添加下載記錄
 
  return response;
  }
  catch
  {
  return new HttpResponseMessage(HttpStatusCode.NoContent);
  }
 
  #endregion 下載文件并添加下載記錄
 }

8、以上只是我個人的一個小Demo,有不對或需要改進的地方還請大家多多提點!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 大香焦在线 | www.男人天堂 | 性刺激欧美三级在线现看中文 | 青青青久在线视频免费观看 | 国产欧美成人免费观看 | 我与白丝同桌的故事h文 | 99精彩视频 | 久久久免费观看 | 日韩精品在线一区二区 | 国产色在线观看 | 欧美色在线 | 亚洲香蕉伊在人在线观看9 亚洲系列国产系列 | 国产精品免费视频能看 | 金发美女与黑人做爰 | 美女用屁股把人吞进肚子 | 肉文高h文 | 东北恋哥在线播放免费播放 | 日本老妇人乱视频 | 五月丁开婷婷 | 国产精品久久现线拍久青草 | 吃瓜视频在线观看 | 国内精品91久久久久 | 95在线观看精品视频 | 日本大学jalapsikix | 国产精品亚洲片在线不卡 | 99热这里只有精品在线播放 | 亚洲国产精品久久网午夜小说 | 国产一级片视频 | 国产亚洲精品看片在线观看 | 秋霞黄色大片 | 激情综合 | 日本视频高清免费观看xxx | 狠狠色成人综合网图片区 | 操小女人| 91大神第九部红酒气质女 | 国产精品第3页 | 欧美s级人做人爱c视频 | 亚洲国产综合久久精品 | 91久久国产综合精品 | 色综合九九 | 加勒比一本大道香蕉在线视频 |