<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. Android ActionBarSherlock使用教程

    Android ActionBarSherlock使用教程 本文转自 http://www.chenwg.com/android/actionbarsherlock%E4%BD%BF%E7%94%A8 ...

  2. sql2008 将行转为字符串, 将字符串转为行 互转

    --将行转为字符串 select stuff((select top 20 ','+ QQ from dl_QQ where uiid=1 order by tim desc for xml path ...

  3. 真实赛车3,SPEEDRUSH TV 第3季,第3阶段(第3天),直线加速赛

    与其跳过,不如金币升级引擎和车身.因为后边紧跟一场计时赛.

  4. 剑指offer系列46---和为s的连续正数序列

    [题目]输出所有和为S的连续正数序列.序列为:1,2,3,4,5,6,7,8................ * 序列内按照从小至大的顺序,序列间按照开始数字从小到大的顺序 package com.e ...

  5. java-多态性

    1 多态性 主要表现在上转型对象 2 强制类型转换 2.1 基本类型的强制类型转换 转换只能在数值间进行.包括整数型.字符型.浮点型.数值类型和布尔类型间不能转换. 2.2 引用类型变量转换成其子类型 ...

  6. Import SHA2 SSL cert to Windows IIS7

    Import SHA2 SSL cert to Windows IIS7 1.You will get 3 piece of certs from GeoTrust, and save them to ...

  7. 151. Reverse Words in a String

    Given an input string, reverse the string word by word. For example,Given s = "the sky is blue& ...

  8. C#属性访问器

    属性的访问器包含与获取或设置属性有关的可执行语句.访问器声明可以包含 get 访问器或 set 访问器,或者两者均包含.声明采用下列形式之一:get {}set {} get 访问器get 访问器体与 ...

  9. DBA_Oracle基本体系内存和进程结构(概念)

    2014-08-05 Created By BaoXinjian

  10. Codeforces Round #359 (Div. 2)C - Robbers' watch

    C. Robbers' watch time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...