Ajax跨域访问
Ajax如何跨域访问数据
最近在做项目的过程中遇到的问题,一个网站需要访问另外一个网站的数据,并且是通过脚本的方式,而由于同源策略的限制,开发人员不能再与外部服务器进行通信的时候使用XMLHttpRequest。而JSONP是一种可以绕过同源策略的方法,即通过使用JSON与<script>标记相结合的方法,从服务器端直接返回可执行的JavaScript函数或者JavaScript对象。目前JSONP已成为大部分公司的Web应用程序跨域首选,尽管JSONP是一个非官方的协议,关于JSONP的介绍,网上一大把;现在开始介绍如何跨域访问数据。
开发环境:Visual Studio 2008 + jQuery
前端代码(调用方):
var baseUrl = "http://localhost:59334/";
$.ajax({
url: baseUrl + "Account/ValidateCode?validateCode=" + code + "&jsoncallback=?",
type: 'GET',
dataType: 'JSON',
success: function(data) {
console.log(data.Content);
},
error: function() {
console.log(arguments);
}
});
后台代码(被调用方,C#):
public String ValidateCode(String validateCode)
{
String callback = Request["jsoncallback"];
String result = "";
if (Session["CaptchaCode"] != null)
{
if (Session["CaptchaCode"].ToString().ToLower() != validateCode.ToLower())
{
result = "0";
if (!String.IsNullOrEmpty(callback))
{
result = callback + "({Success:'True',Content:'0'})";
}
}
else
{
tick = 0;
emailValiCodeExpired = false;
result = "1";
if (!String.IsNullOrEmpty(callback))
{
result = callback + "({Success:'True',Content:'1'})";
}
}
}
if (String.IsNullOrEmpty(result))
{
if (!String.IsNullOrEmpty(callback))
{
result = callback + "({Success:'True',Content:'0'})";
}
else
{
result = "0";
}
}
return result;
}
调用方和被调用方是两个Web应用程序;
关于"jsoncallback=?",在发送ajax请求时,jQuery自动把jsoncallback后面的 "?" 替换为正确的函数名(回调函数)
(一般长这个样:"jQuery1830798391871119546_1449898179923"),以执行回调函数,所以在C#返回的字符串应该这样写:
String result = callback + "({Success:'True',Content:'1'})";
其实返回的是形如下方的一段jQuery脚本:
"jQuery1830798391871119546_1449898179923({Success:'True',Content:'1'})"
注意红色字部分,这是一段json格式的数据,因为,发送ajax请求时要求返回的数据格式是JSON
切不可将result写成这样:return Json(result, JsonRequestBehavior.AllowGet);写成这样的话,回调函数就被序列化了,最终也没法执行;
常见的错误: 1 jQuery1830798391871119546_1449898179923 was not called
2 parsererror
3 已阻止跨源请求:同源策略禁止读取位于 http://localhost:59334/Account/ValidateCode?validateCode=rucr 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。
第一个错误可能是由于发送ajax请求时未加入"jsoncallback=?"这一句
如果dataType写的是"JSONP",那么请求的url里面可以不带"jsoncallback=?",服务器端需要用Request["callback"]来获取回调函数,也就是形如下方代码:
前端代码:
$.ajax({
url: baseUrl + "Account/ValidateCode?validateCode=" + code,
type: 'GET',
dataType: 'JSONP',
success: function(data) {
console.log(data.Content);
},
error: function() {
console.log(arguments);
}
});
后台代码(简写):
String callback = Request["callback"];
String result = callback + "({Success:'True',Content:'1'})";
return result;
一般错误2会和错误1一起出现,可能是返回的结果中{Success:'True',Content:'1'}这部分代有误,造成回调函数没法解析JSON数据;
至于错误3则是跨域失败,在发送ajax请求时就有问题,可能是请求的url没加"jsoncallback=?"也可能是dataType没指定为"JSONP"格式,注意:
在URL里面加jsoncallback=?和dataType指定为"JSONP",二选一即可;如果dataType是"JSONP",那么发送请求时,jQuery会自动在url里面加上 callback=jQuery1830798391871119546_1449898179923这句,上面有说明,不再赘述;
OK说明完毕!
Ajax跨域访问的更多相关文章
- 浅析JSONP-解决Ajax跨域访问问题
浅析JSONP-解决Ajax跨域访问问题 很久没有写随笔了,总是感觉没时间,其实时间就是...废话少说,前几天,工作上有一新需求,需要前端web页面异步调用后台的Webservice方法返回信息.实现 ...
- ajax跨域访问的解决方案
今天的工作中要访问摄像机内部的一个web站点,这就涉及到jquery的ajax跨域访问的问题.我使用的是jquery1.7的版本,下面总结如下: 问题一:一开始用IE调试,总是返回No Transpo ...
- Ajax跨域访问解决办法
方法1. jsonp实现ajax跨域访问示例 jsp代码: <body> <input type="button" onclick="testJsonp ...
- Web Api 2(Cors)Ajax跨域访问
支持Ajax跨域访问ASP.NET Web Api 2(Cors)的简单示例教程演示 随着深入使用ASP.NET Web Api,我们可能会在项目中考虑将前端的业务分得更细.比如前端项目使用Ang ...
- ajax 跨域访问的解决方案
ajax 跨域访问的解决方案 一.什么是跨域: 1.什么样的请求属于跨域: 域名,端口有任何一个不相同都属于跨域: 二.跨域的常用几种解决方案: 1.jsonp: 2.iframe: 3.webcon ...
- Hbuilder编辑App时,ajax跨域访问失败问题
今天试着用Hbuilder写app的前段显示页面,在第一步时就被打住了,ajax异步调用服务器的登录接口时,报错, 显示这样的错误 XMLHttpRequest cannot loadhttp://w ...
- 关于JQuery Ajax 跨域 访问.net WebService
关于这个 jQuery Ajax跨域访问 WebService 前天整了好几个小时没整明白 今天再看一下 结果突然就顿悟了 1.建一个空webApplication --添加--新建项--web服务( ...
- JS Ajax跨域访问
js ajax跨域访问报"No 'Access-Control-Allow-Origin' header is present on the requested resource 如果请求的 ...
- ajax跨域访问http服务--jsonp
在前面一篇文章<Spring Cloud 前后端分离后引起的跨域访问解决方案>里我们提到使用ajax跨域请求其他应用的http服务,使用的是后台增加注解@CrossOrigin或者增加Co ...
- Ajax跨域访问wcf服务中所遇到的问题总结。
工具说明:vs2012,sql server 2008R2 1.首先,通过vs2012建立一个wcf服务项目,建立好之后.再新开一个vs2012 建立web项目,通过jQuery的ajax方法访问服务 ...
随机推荐
- 测试加载jquery
Hello world! <h1 id="main-heading">Hello world!</h1> <p><img onclick= ...
- 后台给前台传JSON字符串,前台解析并拼接显示
后台传JSON public class CourseType : IHttpHandler { Epoint.PeiXun.Bizlogic.BLL.CourseLibrary.PX_CourseT ...
- android 底层开发入门(一)
第一个Linux驱动程序:统计单词个数 一.首先了解一下: 打印机驱动写入数据:对于打印机驱动来说,需要接收这些被写入的数据,并将它们通过PC的并口.USB等端口发送给打印机.要实现这一过程就需要Li ...
- java的三大框架(三)---Hibernate
一.什么是映射 这里所说的映射就是对象关系映射:将对象数据保存到数据库中,同时可以将数据库数据读入对象中,开发人员只对对象进行操作就可以完成对数据库数据的操作. 二.什么是基本映射 知道了什么是映射, ...
- CentOS7防火墙
一.CentOS7依然使用iptables的方法 CentOS7不再使用iptables,而是使用firewalld,若不想使用firewalld,可以停掉firewalld并且安装iptables- ...
- chrome浏览器定位页面元素对应代码查找资源
F12 左边箭头或ctrl shift c 点击相应元素即可定位代码 应用:定位flash游戏代码后,鼠标移至带下划线链接处右键copy link
- 初识linux端c++程序开发
关于linux端程序开发,我以前一直不知道是做些什么,只是感觉听高端的.最近接触了一些,有了一些初步的认识. 首先,linux是一个操作系统,跟windows一样:接通电源.按下电脑开机,电脑就会自动 ...
- 转 MySQL 数据备份与还原
MySQL 数据备份与还原 原贴:http://www.cnblogs.com/kissdodog/p/4174421.html 一.数据备份 1.使用mysqldump命令备份 mysqldum ...
- linux shell:nginx日志切割脚本
需求原因:nginx不具备日志切割功能,日志量较大,方便分析. 实现目的:完成nginx日志切割,并根据时间命名 简要命令: mv /usr/local/tengine/logs/access.l ...
- delphi如何让程序最小化到任务栏(转)
现在很多的应用程序都有这样一种功能,当用户选择最小化窗口时,窗口不是象平常那样最小化到任务栏上,而是“最小化”成一个任务栏图标.象FoxMail 3.0 NetVampire 3.0等都提供了这样的功 ...