<input type="file" name="btn_Upload" value="上传" id="btn_Upload" />
<img src="" alt="" id="img_Upload" /> @section Scripts
{
<link href="../../js/uploadifive-v1.2.2-standard/uploadifive.css" rel="stylesheet" />
<script src="../../js/uploadifive-v1.2.2-standard/jquery.uploadifive.js"></script>
} <script>
$(function () {
$('#btn_Upload').uploadifive({
formData: { openId: '@ViewBag.OpenId' },
multi: false,
uploadScript: '@WXCommon.ConfigHelper.UploadUrl',
onUploadComplete: function (file, data) {
if (data) {
var json = $.parseJSON(data);
if (json.res) {
alert(json.msg);
$('#img_Upload').attr({
src: '@WXCommon.ConfigHelper.ThumbnailPath' + '/' + '@ViewBag.OpenId' + '/' + json.fileName
});
} else {
alert(json.msg);
}
} else {
alert('服务器内部错误!');
}
}
});
});
</script>

Javascript

 //独立部署的图片服务器
public ActionResult Index()
{
//if (Request.HttpMethod == "OPTION")
//{
// Response.AddHeader("Access-Control-Allow-Methods", "GET,POST");
// Response.AddHeader("Access-Control-Allow-Headers", "Content-Type,Accept");
// Response.AddHeader("Access-Control-Max-Age", "1728000");
// Response.AddHeader("Access-Control-Allow-Origin", "*");
//}
string openId = Request["openId"];
HttpPostedFileBase httpPostedFileBase = Request.Files["Filedata"];
string fileName = httpPostedFileBase.FileName;
string extensionName = System.IO.Path.GetExtension(fileName).ToLower();
if (extensionName == ".jpg" || extensionName == ".jpeg")
{
string virtualPath = "/uploads" + "/" + fileName.Replace(extensionName, "") + DateTime.Now.ToString("yyyyMMddhhmmss") + extensionName;
string fullPath = Server.MapPath(virtualPath);
httpPostedFileBase.SaveAs(fullPath); string savePath = Server.MapPath("/thumbnails" + "/" + openId);
string thumbnailFileName = Thumbnail.GetThumbnailImage(, , fullPath, savePath, System.Drawing.Imaging.ImageFormat.Jpeg);
//删除原始文件
//System.IO.File.Delete(fullPath);
NowModel model = new NowModel();
model.Id = ;
model.OpenId = openId;
model.FileName = thumbnailFileName;
nowBLL.Insert(model);
return Json(new { res = true, msg = "上传成功!", fileName = thumbnailFileName });
}
return Json(new { res = false, msg = "上传失败!" });
}

ASP.Net

   <!--仅试用于IIS7以上版本,IIS6.0请用Response.AddHeader的方式-->
<system.webServer>
<validation validateIntegratedModeConfiguration="false" />
<httpProtocol>
<customHeaders>
<add name="Access-Control-Allow-Origin" value="*"/>
<add name="Access-Control-Allow-Methods" value="GET,POST,OPTION"/>
<add name="Access-Control-Allow-Headers" value="Content-Type,soapaction"/>
</customHeaders>
</httpProtocol>
</system.webServer>

图片服务器配置文件

启用 CORS 来解决这个问题(ajax跨域请求)的更多相关文章

  1. 解决ajax跨域请求 (总结)

    ajax跨域请求,目前已用几种方法实现:   1)用原生js的xhr对象实现.                var url="http://freegeoip.net/json/" ...

  2. jQuery ajax跨域请求的解决方法

    在Ajax应用中,jQuery的Ajax请求是非常容易而且方便的,但是初学者经常会犯一个错误,那就是Ajax请求的url不是本地或者同一个服务器下面的URI,最后导致虽然请求200,但是不会返回任何数 ...

  3. 用iframe设置代理解决ajax跨域请求问题

    面对ajax跨域请求的问题,想用代理的方式来解决这个跨域问题.在服务器端创建一个静态的代理页面,在客户端用iframe调用这个代理 今天在项目中需要做远程数据加载并渲染页面,直到开发阶段才意识到aja ...

  4. Jquery DataTable AJAX跨域请求的解决方法及SSM框架下服务器端返回JSON格式数据的解决方法

    如题,用HBuilder开发APP,涉及到用AJAX跨域请求后台数据,刚接触,费了不少时间.幸得高手指点,得以解决. APP需要用TABLE来显示数据,因此采用了JQ 的DataTable.  在实现 ...

  5. JQuery的Ajax跨域请求的解决方式

            今天在项目中须要做远程数据载入并渲染页面,直到开发阶段才意识到ajax跨域请求的问题,隐约记得Jquery有提过一个ajax跨域请求的解决方式,于是即刻翻出Jquery的API出来研究 ...

  6. 第114天:Ajax跨域请求解决方法(二)

    一.什么是跨域 我们先回顾一下域名地址的组成: http:// www . google : 8080 / script/jquery.js   http:// (协议号)       www  (子 ...

  7. 第113天:Ajax跨域请求解决方法

    一.原生JS实现ajax 第一步获得XMLHttpRequest对象 第二步:设置状态监听函数 第三步:open一个连接,true是异步请求 第四部:send一个请求,可以发送一个对象和字符串,不需要 ...

  8. Ajax跨域请求怎么解决?

    前言 项目中需要将第三方系统中,对应用户的代办消息集成到系统中.对方提供了获取对应用户的接口url,但是由于两边的系统是部署到客户现场不同IP的虚机上的,所以进行ajax请求的时候是属于跨域请求的.之 ...

  9. Ajax跨域请求以及乱码解决

    Ajax跨域请求2种解决方法 1 ) 什么叫跨域请求,协议,域名,端口号,其中一样不同都称跨域; 第一种:使用script标签发送请求; //创建一个script标签; var v_element=d ...

  10. 如何解决ajax跨域请求?

    1.什么是跨域? a.域名不同 b.域名相同,端口不同 注:只有域名相同,端口相同时,才可以访问数据 可以使用jsonp解决ajax跨域请求的问题. 2.什么是jsonp? Jsonp其实就是一个跨域 ...

随机推荐

  1. jquery的$.extend和$.fn.extend作用及区别.txt

    jQuery为开发插件提拱了两个方法,分别是: jQuery.fn.extend(); jQuery.extend(); (1)类级别 类级别你可以理解为拓展jquery类,最明显的例子是$.ajax ...

  2. Redis 利用锁机制来防止缓存过期产生的惊群现象-转载自 http://my.oschina.net/u/1156660/blog/360552

    首先,所谓的缓存过期引起的“惊群”现象是指,在大并发情况下,我们通常会用缓存来给数据库分压,但是会有这么一种情况发生,那就是在一定时间 内生成大量的缓存,然后当缓存到期之后又有大量的缓存失效,导致后端 ...

  3. MyBatis插入多条

    <insert id="insertProjectPropertyRelList" parameterType="java.util.List"> ...

  4. 异步I/O编程实例,异步socket

    下载地址: http://files.cnblogs.com/badnewfish/RUYEESocket.rar ———————————————————————————————————————— 举 ...

  5. 一个自己做的easyui datagird扩展

    var a; $(function () { $("body").bind("contextmenu", function () { return false; ...

  6. 【转】linux-系统启动流程详解

    第二十章.启动流程.模块管理与 Loader 最近升级日期:2009/09/14 1. Linux 的启动流程分析 1.1 启动流程一览 1.2 BIOS, boot loader 与 kernel ...

  7. bzoj3034: Heaven Cow与God Bull

    Description __int64 ago,there's a heaven cow called sjy...A god bull named wzc fell in love with her ...

  8. php 查询出来的字段名全是小写或者大写

    PHP PDO预定义常量 PDO::CASE_LOWER -- 强制列名是小写PDO::CASE_NATURAL -- 列名按照原始的方式PDO::CASE_UPPER -- 强制列名为大写 修改此参 ...

  9. BIP_开发案例05_BI Pubisher标准做法以BIP.XML为数据源以BIP.RTF为模板的简单例子(案例)

    2014-05-31 Created By BaoXinjian

  10. HDU 3001 Traveling(状压DP)

    题目大意:10个点的TSP问题,但是要求每个点最多走两边,不是只可以走一次,所以要用三进制的状态压缩解决这个问题.可以预处理每个状态的第k位是什么. 原代码链接:http://blog.csdn.ne ...