C# Web Api 上传文件
一、 使用默认方法上传文件:
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 <= || 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>
C# Web Api 上传文件的更多相关文章
- 演示如何通过 web api 上传文件MVC40
演示如何通过 web api 上传文件WebApiWebFormHost/UploadFileController.cs /* * 通过 web api 上传文件 */ using System; u ...
- 返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, .net 4.5 带来的更方便的异步操作
原文:返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, ...
- 前端AngularJS后端ASP.NET Web API上传文件
本篇体验使用AngularJS向后端ASP.NET API控制器上传文件. 首先服务端: public class FilesController : ApiController { //usi ...
- 1.5 WEB API 上传文件
1.前提,设置跨域 2.在控制器头添加允许跨域 /// <summary> /// 文件管理口控制器 /// </summary> [EnableCors("*&qu ...
- HttpClient 测试web API上传文件实例
1.使用HttpClient 测试上传文件并且设置header信息: using Lemon.Common; using Newtonsoft.Json; using System; using Sy ...
- ASP.NET Web API 上传文件
HTML表单: <form id="form1" method="post" enctype="multipart/form-data" ...
- 数据採集之Web端上传文件到Hadoop HDFS
前言 近期在公司接到一个任务.是关于数据採集方面的. 需求主要有3个: 通过web端上传文件到HDFS; 通过日志採集的方式导入到HDFS; 将数据库DB的表数据导入到HDFS. 正好近期都有在这方面 ...
- php 下 html5 XHR2 + FormData + File API 上传文件
FormData的作用: FormData对象可以帮助我们自动的打包表单数据,通过XMLHttpRequest的send()方法来提交表单.当然FormData也可以动态的append数据.FormD ...
- Web API 上传下载文件
1.引用了一个第三方组件 ICSharpCode.SharpZipLib.Zip; 2.具体代码 实体类,可以用hashtable 替代 ,感觉hashtable 比较灵活 public class ...
随机推荐
- yii2 [行为] behaviors 拦截器
yii2 拦截器 在控制器中可以自定义对action的拦截器,拦截器需要继承 \yii\base\ActionFilter 参考代码: class BaseUserAuthorizeFilter ex ...
- osgi: HttpService A null service reference is not allowed.
最近在学习osgi,在练习HttpService的过程中,一直出现“A null service reference is not allowed”这样的报错,代码本身没有问题,在网上也搜了不少地方, ...
- ionic 实现自动升级APP
最近做移动商城开发,需要一个自动升级APP的功能,在网上搜罗很多,发现有的是下载APK,有的在我这服务无法实现,由于时间原因,都被PASS了,最后找到了一个热更新插件,经过半天的调试,可以使用,很欣喜 ...
- Linux - 文本格式转换
文本文档格式查看 Linux下的文档格式查看方法 cat -A <filename> | grep "^M$", 如果存在^M$字符就是Dos格式. Windows下的 ...
- 使用 GistBox 轻松组织和管理你的代码片段
GistBox 用简便的方式来组织和管理代码片段.你的代码会保存到云端进行备份,再也不用担心迷失在杂乱的代码片段中.GistBox 是建立在标准的 HTML5 技术基础上.在旅途中或在办公室,你都可以 ...
- MySQL安全问题(防范必知)
对于任何一种数据库来说,安全问题都是非常重要的.如果数据库出现安全漏洞,轻则数据被窃取,重则数据被破坏,这些后果对于一些重要的数据库都是非常严重的.下面来从操作系统和数据库两个层对MySQL的安全问题 ...
- 还在抱怨JS文件里没有智能提示吗, VS10以及以上都可以 .NET
1.打开JS文件 2.编写$.我们会发现什么也没有 3.托进来 4.有了哈 保存头部代码新建JS都贴上去.
- iOS性能优化之内存管理:Analyze、Leaks、Allocations的使用和案例代码
最近接了个小任务,和公司的iOS小伙伴们分享下instruments的具体使用,于是有了这篇博客...性能优化是一个很大的话题,这里讨论的主要是内存泄露部分. 一. 一些相关概念 很多人应该比较了解这 ...
- Const的用法
宏和const的区别: 1.宏执行的是替换操作,这也就意味着会在内存中开辟多个临时空间 这样显然不是很好 2.宏不可以修改 const : 用const修饰的变量 为常量 不能修改,在内存中只有一份内 ...
- GPUImage滤镜之锐化
应用锐化工具可以快速聚焦模糊边缘,提高图像中某一部位的清晰度或者焦距程度,使图像特定区域的色彩更加鲜明. 在应用锐化工具时,若勾选器选项栏中的“对所有图层取样”复选框,则可对所有可见图层中的图像进行锐 ...