前几天朋友说用js上传图片过去遇到点问题,于是自己也想写一个demo这里就把自己挖的坑填了。

话不多说上代码

前台就一个file控件加按钮

<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<title></title>
<script src="scripts/jquery-1.9.1.min.js"></script>
</head> <body>
<input type="file" name="file" id="testFile" nultiple="multiple" />
<input type="button" id="btnSend" value="上传" onclick="UploadFile()" /> <script>
function UploadFile() {
var formData = new FormData();
jQuery.support.cors = true;
var file = $("#testFile")[0].files[0];
formData.append("file", file);
$.ajax({
type: "post",
url: "./api/file/FileByAsyncTask",
data: formData,
async: false,
/**
*必须false才会自动加上正确的Content-Type
*/
contentType: false,
/**
* 必须false才会避开jQuery对 formdata 的默认处理
* XMLHttpRequest会对 formdata 进行正确的处理
*/
processData: false,
success: function (data) {
console.log(data);
},
error: function (data) {
console.log(data.statusText);
}
});
}
</script>
</body>
</html>

这里需要注意的就是在发送文件的时候需要使用FormData进行传递

后台代码(用了三种方式处理)
public class FileController : ApiController
{
TimeSpan tspan = DateTime.Now - new DateTime(, , ); /// <summary>
/// 图片上传接口
/// </summary>
/// <returns></returns>
[HttpPost]
public HttpResponseMessage FileUpload()
{
if (!Request.Content.IsMimeMultipartContent("form-data"))
throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
HttpResponseMessage response = new HttpResponseMessage();
try
{
HttpPostedFile file = HttpContext.Current.Request.Files["file"];//获取http传输的文件
string domainPath = HttpRuntime.AppDomainAppPath.ToString();//物理路径 二选一
string serverPath = System.Web.Hosting.HostingEnvironment.MapPath("~/images/img/");//物理路径
string ext = Path.GetExtension(file.FileName);//获取扩展名
string newName = tspan.TotalMilliseconds + ext;//时间戳+扩展名形成新文件名 //方式一 直接保存上传文件
//FileByHttpPostedFile(file,serverPath,tspan.TotalMilliseconds+ext); //方式二 图片流处理
//ImageByStream(file, serverPath, newName); //方式三 先创建文件在移动到指定目录 response.Headers.Add("Access-Control-Allow-Origin", "*");
response.Headers.Add("Access-Control-Alow-Method", "post");
response.Headers.Add("Access-Control-Allow-Headers", "Content-Type");
response.Headers.Add("Access-Control-Max", "");
return response;
}
catch (Exception e)
{
throw e;
}
} /// <summary>
/// 方法一 通过HttpPostedFile保存
/// </summary>
/// <param name="file">Http接收到的文件</param>
/// <param name="savePath">保存地址</param>
/// <param name="filename">文件名</param>
public void FileByHttpPostedFile(HttpPostedFile file, string serverPath, string fileName)
{
file.SaveAs(serverPath + fileName);
} public void ImageByStream(HttpPostedFile file, string serverPath, string fileName)
{
using (Image img = Bitmap.FromStream(file.InputStream))
{
img.Save(serverPath + fileName);
}
} /// <summary>
/// 异步上传
/// </summary>
/// <param name="postFile"></param>
/// <returns></returns>
[HttpPost]
public async Task<bool> FileByAsyncTask()
{
if (!(HttpContext.Current.Request.Files.Count > ))//判断是否文件
return false;
HttpPostedFile postFile = HttpContext.Current.Request.Files["file"];//获取文件
string serverPath = System.Web.Hosting.HostingEnvironment.MapPath("~/images/img/");//获取服务器地址
var provider = new MultipartFormDataStreamProvider(serverPath);//创建MIME 多部分正文新实例
IEnumerable<HttpContent> parts = null;
Task.Factory.StartNew(() =>
{
parts = Request.Content.ReadAsMultipartAsync(provider).Result.Contents;//异步获取多部分正文内容
},CancellationToken.None,
TaskCreationOptions.LongRunning,
TaskScheduler.Default).Wait();
foreach (var file in provider.FileData)//文件保存
{
FileInfo _fileInfo = new FileInfo(file.LocalFileName);
var fileName = file.Headers.ContentDisposition.FileName.Replace("\"","");//从内容读取文件名
string _ext = Path.GetExtension(fileName);//content获取文件名是 \"header.jpg\" 函数识别字符串 header.jpg所以需要去掉双引号
string _savePath = Path.Combine(serverPath + tspan.TotalMilliseconds + _ext);
_fileInfo.MoveTo(_savePath);
}
return true;
}
}

比较菜,希望以后继续努力

												

c#使用js上传图片的更多相关文章

  1. JS 上传图片 + 预览功能(一)

    JS 上传图片 + 预览功能 <body> <input type="file" id="fileimg1" style="disp ...

  2. js上传图片前预览方法(支持预览多个图片)

    运用js实现上传图片前的预览(支持多张图片),实现的例子如下: 1.源码例子: 1)Js脚本页面 <!doctype html> <html> <head> < ...

  3. Node.js 上传图片并保存

    Node.js 上传图片并保存 依赖 package.json 文件 { "name": "demo", "version": " ...

  4. js 上传图片、压缩、旋转

    亲测 <!doctype html> <html> <head> <meta charset="utf-8"> <title& ...

  5. 原生 js 上传图片

    js <!doctype html> <html> <head> <meta charset="utf-8"> <title& ...

  6. Js上传图片并生成缩略图

    Js上传图片并显示缩略图的流程为 Js选择文件->Jquery上传图片->服务器接收图片流->存储图片->返回结果到Js端->显示缩略图 本文上传图片所用的Js库是aja ...

  7. js上传图片到七牛云存储

    项目开发过程中遇到一个需求,运营人员需要上传图片到七牛云,最开始的做法是,后台对接七牛,然后出一个接口,前端调用接口,先将图片传到后台,然后后台再上传七牛云,用的过程中发现,图片小的情况下还好,图片一 ...

  8. js 上传图片,用户自定义截取图片大小

    js 上传图片,用户自定义截取图片大小 js 组件

  9. js上传图片及预览功能

    详细内容请点击 参考了网上一些人代码写了一个上传图片及时预览的功能 <img id="imgTag" style="height: 100px;" alt ...

随机推荐

  1. EF学习笔记(十一):实施继承

    学习总目录:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 上篇链接:EF学习笔记(十) 处理并发 本篇原文链接:Implementing Inheritance 面向对象的世界里, ...

  2. day_4流程控制之分支结构循环结构及for循环

    复习一下昨天的内容 1:变量的命名规范 只能由数字 字母 及下划线组成 不能以数字开头 不能与系统关键字重名 _开头有特殊含义 __开头__结尾的变量是魔法变量 支持大小驼峰 ,但建议使用下划线连接语 ...

  3. C++面试基础之回调

    回调函数技术广泛运用在动态库开发(或者类库)中,是使软件模块化的重要手段.回调函数可以看作是一种通知和实现机制,用于控制反转,即模块A调用模块B时,模块B完成一定任务后反过头来调用模块A.在被调用方代 ...

  4. Lesson 22 A glass envelope

    Text My daughter, Jane, never dreamed of receiving a letter from a girl of her own age in Holland. L ...

  5. 背水一战 Windows 10 (96) - 选取器: ContactPicker

    [源码下载] 背水一战 Windows 10 (96) - 选取器: ContactPicker 作者:webabcd 介绍背水一战 Windows 10 之 选取器 ContactPicker(联系 ...

  6. ZJOI2019二试游记

    ZJOI2019二试游记 Day -2 今天就要去被虐了!开一篇占个坑.禁赛警告 Day -1 早上zzy,下午zzq,无限懵逼... 过来的时候Sooke,memset0,老K坐我旁边,瑟瑟发抖.. ...

  7. Not posting notification with icon==0问题解决

    问题:E/NotificationService: Not posting notification with icon==0: Notification(pri=0 contentView=null ...

  8. shell脚本中if的“-e,-d,-f”

    文件表达式-e filename 如果 filename存在,则为真-d filename 如果 filename为目录,则为真 -f filename 如果 filename为常规文件,则为真-L ...

  9. Metrics.NET源码阅读笔记

    概述 Metrics.NET提供的是度量工具,他是移植自Java的metrics.Metrics将度量抽象成Gauges,Counters,Histograms,Meters,Timers五种.基于这 ...

  10. 改变input的值不会触发change事件的解决思路

    通常来说,如果我们自己通过 value 改变了 input 元素的值,我们肯定是知道的,但是在某些场景下,页面上有别的逻辑在改变 input 的 value 值,我们可能希望能在这个值发生变化的时候收 ...