一、 使用默認方法上傳文件:
1、Action:
/// <summary> /// 上傳文件 使用上傳后的默認文件名稱 /// 默認名稱是BodyPart_XXXXXX,BodyPart_加Guid碼 /// </summary> /// <returns></returns> [HttpPost, Route("Upload")] public async Task<string> Upload() { try { //web api 獲取項目根目錄下指定的文件下 var root = System.Web.Hosting.HostingEnvironment.MapPath("/Resource/Images"); var provider = new MultipartFormDataStreamProvider(root); //文件已經上傳 但是文件沒有后綴名 需要給文件添加后綴名 await Request.Content.ReadAsMultipartAsync(provider); foreach (var file in provider.FileData) { //這里獲取含有雙引號'" ' string filename = file.Headers.ContentDisposition.FileName.Trim('"'); //獲取對應文件后綴名 string fileExt = filename.Substring(filename.LastIndexOf('.')); FileInfo fileinfo = new FileInfo(file.LocalFileName); //fileinfo.Name 上傳后的文件路徑 此處不含后綴名 //修改文件名 添加后綴名 string newFilename = fileinfo.Name + fileExt; //最后保存文件路徑 string saveUrl = Path.Combine(root, newFilename); fileinfo.MoveTo(saveUrl); } return "success"; } catch (Exception ex) { throw ex; } }
2、html模擬代碼:
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> </head> <body> <h1>檸檬伙伴雲</h1> <form action="/Test/Upload" method="post" enctype="multipart/form-data"> <input type="file" name="f1" /> <br /><br /> <input type="file" name="f2" /> <br /><br /> <input type="submit" value="上傳圖片" /> </form> </body> </html>
3、效果如下圖:
上圖就是上傳后文件沒有后綴名效果
對第一張沒有后綴名添加后綴名的效果
二、修改上傳文件后綴名
1、action:
/// <summary> /// 上傳文件 修改上傳文件名稱 也不包含后綴名 /// </summary> /// <returns></returns> [HttpPost, Route("Upload2")] public async Task<string> Upload2() { try { //web api 獲取項目根目錄下指定的文件下 var root = System.Web.Hosting.HostingEnvironment.MapPath("/Resource/Images"); //對上傳文件重新命名 根據需求對應修改文件名稱 不包含后綴名 只是前綴名 var provider = new RenamingMultipartFormDataStreamProvider(root); //文件已經上傳 但是文件沒有后綴名 需要給文件添加后綴名 await Request.Content.ReadAsMultipartAsync(provider); foreach (var file in provider.FileData) { //這里獲取含有雙引號'" ' string filename = file.Headers.ContentDisposition.FileName.Trim('"'); //獲取對應文件后綴名 string fileExt = filename.Substring(filename.LastIndexOf('.')); FileInfo fileinfo = new FileInfo(file.LocalFileName); //fileinfo.Name 上傳后的文件路徑 此處不含后綴名 //修改文件名 添加后綴名 string newFilename = fileinfo.Name + fileExt; //最后保存文件路徑 string saveUrl = Path.Combine(root, newFilename); fileinfo.MoveTo(saveUrl); } return "success"; } catch (Exception ex) { throw ex; } }
2、RenamingMultipartFormDataStreamProvider 類:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Net.Http; using System.Net.Http.Headers; using System.IO; namespace Test.One.Common { public class RenamingMultipartFormDataStreamProvider : MultipartFormDataStreamProvider { /// <summary> /// 文件重命名 /// </summary> /// <param name="root"></param> public RenamingMultipartFormDataStreamProvider(string root) : base(root) { } /// <summary> /// 文件重命名 /// </summary> /// <param name="headers"></param> /// <returns></returns> public override string GetLocalFileName(HttpContentHeaders headers) { string fileName = headers.ContentDisposition.Name; if (!string.IsNullOrWhiteSpace(fileName)) { fileName = Guid.NewGuid().ToString(); } return fileName.Replace("\"", string.Empty); } } }
3、html 模擬代碼:
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> </head> <body> <h1>檸檬伙伴雲</h1> <form action="/Test/Upload2" method="post" enctype="multipart/form-data"> <input type="file" name="f1" /> <br /><br /> <input type="file" name="f2" /> <br /><br /> <input type="submit" value="上傳圖片" /> </form> </body> </html>
3、效果:
實例二:
api:
/// <summary> /// TestFile /// </summary> /// <returns></returns> [HttpPost,Route("TestFile")] public async Task<Result<bool>> TestFile() { Result<bool> result = new Result<bool>(); try { if (!Request.Content.IsMimeMultipartContent()) { result.ReturnCode = ResultCode.InvalidParam; result.Data = false; result.ReturnMsg = "請求數據不是multipart/form-data類型"; return result; } string root = HostingEnvironment.MapPath("/Resources/Templet/"); string date = DateTime.Now.ToString("yyyy-MM-dd"); string resourcePath = Path.Combine(root, date); if (!Directory.Exists(resourcePath)) { Directory.CreateDirectory(resourcePath); } var provider = new RenamingMultipartFormDataStreamProvider(resourcePath); // 接收數據,並保存文件 var bodyparts = await Request.Content.ReadAsMultipartAsync(provider); if (bodyparts.FormData.Count <= 0 || provider.FileData == null && !provider.FileData.Any()) { result.ReturnCode = ResultCode.InvalidParam; result.Data = false; result.ReturnMsg = "文件或參數不全,視頻上傳失敗。"; return result; } UploadContactListFileModel uploadModel = new UploadContactListFileModel(); if (bodyparts.FormData.AllKeys.Contains("ContactListName")) { uploadModel.ContactListName = bodyparts.FormData["ContactListName"]; } foreach (MultipartFileData file in provider.FileData) { //上傳的文件名 string name = file.Headers.ContentDisposition.FileName.Replace("\"", ""); string extension = Path.GetExtension(name); if (extension == ".csv" || extension == ".xls" || extension == ".xlsx") { //修改文件名 string newFileName = Guid.NewGuid().ToString("N") + Path.GetExtension(name); string uploadPath = Path.Combine(resourcePath, newFileName); //保存文件 File.Move(file.LocalFileName, uploadPath); uploadModel.FilePath = uploadPath; break; } } } catch (Exception ex) { result.ReturnMsg = "服務器內部發生異常"; Logger.Error("SelfsController[AddVideos]", ex); } return result; }
model:
public class UploadContactListFileModel { /// <summary> /// FilePath /// </summary> public string FilePath { get; set; } /// <summary> /// ContactListName /// </summary> public string ContactListName { get; set; } /// <summary> /// IsError /// </summary> /// <returns></returns> public bool IsError() { return string.IsNullOrEmpty(FilePath) || string.IsNullOrEmpty(ContactListName); } }
html:
<form action="/Spread/External/TestFile" method="post" enctype="multipart/form-data"> <input type="text" name="ContactListName" value="ContactListName" /> <br /> <input type="file" name="upload" value="" /><br /> <input type="submit" name="name" value="上傳" /> </form>