由于同源策略的缘故,ajax不能向不同域的网站发出请求。

比如a站localhost需要向b站请求数据,地址为:http://www.walk-sing.com/api.php
请求的代码如下:
<html>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script type="text/javascript">
$.get("http://www.walk-sing.com/api.php", function(data){
alert("Data Loaded: " + data);
});
</script>
<body>
</body>
</html>
访问该页面,页面空白,按F12打开控制台,可以看到截图所示信息:
解决方案1:jsonp
我们先来看这样一个例子:
<html>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script type="text/javascript">
function alertSomething(data){
alert(data.name+data.age);
}
alertSomething(
{"name":"ben","age":24}
);
// $.get("http://www.walk-sing.com/api.php", function(data){
// alert("Data Loaded: " + data);
// });
</script>
<body>
</body>
</html>
执行结果:
我们也可以这样写:
<html>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script type="text/javascript">
function alertSomething(data){
alert(data.name+data.age);
};
// $.get("http://www.walk-sing.com/api.php", function(data){
// alert("Data Loaded: " + data);
// });
</script>
<script type="text/javascript" src="alertsomething.js"></script>
<body>
</body>
</html>
alertsomething.js的内容如下:
alertSomething(
{"name":"ben","age":24}
);
也可以得到截图所示结果。
我们再换一个方式,将alertsomething.js上传到服务器,将代码改为如下形式:
<html>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script type="text/javascript">
function alertSomething(data){
alert(data.name+data.age);
};
// $.get("http://www.walk-sing.com/api.php", function(data){
// alert("Data Loaded: " + data);
// });
</script>
<script type="text/javascript" src="http://www.walk-sing.com/alertsomething.js"></script>
<body>
</body>
</html>
也可以得到截图所示结果。
不知道大家发现没有,script标签没有同源策略的限制,jsonp正是基于此原理实现的。
jsonp的具体实现可参见如下代码:
jsonp.php
<?php
$method = isset($_GET['callback']) ? $_GET['callback'] : '';
if(!isset($method)){
exit('bad request');
}
$testArr = array(
'name' => 'ben',
'age' => 23
);
echo $method.'('.json_encode($testArr).')';
js代码:
<html>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script type="text/javascript">
function alertSomething(data){
alert(data.name+data.age);
};
// $.get("http://www.walk-sing.com/api.php", function(data){
// alert("Data Loaded: " + data);
// });
</script>
<script type="text/javascript" src="http://www.walk-sing.com/jsonp.php?callback=alertSomething"></script>
<body>
</body>
</html>
也可以得到截图所示结果。
解决方案二:CORS(跨域资源共享,Cross-Origin Resource Sharing)
不知道大家发现了没有,jsonp只能发送get请求,而如果业务中需要用到post请求时,jsonp就无能为力了。
这时候cors(跨域资源共享,Cross-Origin Resource Sharing)就派上用处了。
CORS的原理:
CORS定义一种跨域访问的机制,可以让AJAX实现跨域访问。CORS 允许一个域上的网络应用向另一个域提交跨域 AJAX 请求。实现此功能非常简单,只需由服务器发送一个响应标头即可。
就拿前面第一个例子来说,我只要在api.php文件头加上如下一句话即可:
header('access-control-allow-origin:*');
再次请求该接口,结果如下截图所示:
以上所述是小编给大家介绍的jsopn跨域请求原理及cors(跨域资源共享)的完美解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# jsonp
# cors跨域请求
# 简单易懂的JSONP和CORS跨域方案详解
# Quarkus中filter过滤器跨域cors问题解决方案
# SpringBoot开发技巧之如何处理跨域请求CORS
# 你可能不知道的CORS跨域资源共享
# CORS cross-origin resourse sharing跨
# 所示
# 可以得到
# 资源共享
# 小编
# 第一个
# 在此
# 我只
# 只需
# 要在
# 给大家
# 这样一个
# 可以看到
# 句话
# 解决方法
# 所述
# 就拿
# 换一个
# 给我留言
# 感谢大家
# 派上
相关文章:
江苏网站制作公司有哪些,江苏书法考级官方网站?
建站之星安装后如何配置SEO及设计样式?
制作网站的软件免费下载,免费制作app哪个平台好?
高防服务器租用指南:配置选择与快速部署攻略
电商网站制作公司有哪些,1688网是什么意思?
*服务器网站为何频现安全漏洞?
制作网页的网站有哪些,电脑上怎么做网页?
建站之星图片链接生成指南:自助建站与智能设计教程
如何选择美橙互联多站合一建站方案?
如何快速生成高效建站系统源代码?
行程制作网站有哪些,第三方机票电子行程单怎么开?
专业商城网站制作公司有哪些,pi商城官网是哪个?
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
TestNG的testng.xml配置文件怎么写
网站制作软件免费下载安装,有哪些免费下载的软件网站?
孙琪峥织梦建站教程如何优化数据库安全?
电商网站制作价格怎么算,网上拍卖流程以及规则?
网站制作免费,什么网站能看正片电影?
如何在Golang中指定模块版本_使用go.mod控制版本号
如何通过多用户协作模板快速搭建高效企业网站?
建站之星安装需要哪些步骤及注意事项?
如何选择靠谱的建站公司加盟品牌?
如何通过西部建站助手安装IIS服务器?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
宿州网站制作公司兴策,安徽省低保查询网站?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
建站之星logo尺寸如何设置最合适?
微课制作网站有哪些,微课网怎么进?
如何在Ubuntu系统下快速搭建WordPress个人网站?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
海南网站制作公司有哪些,海口网是哪家的?
网站制作公司排行榜,抖音怎样做个人官方网站
广德云建站网站建设方案与建站流程优化指南
Android滚轮选择时间控件使用详解
小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建
个人摄影网站制作流程,摄影爱好者都去什么网站?
Android自定义控件实现温度旋转按钮效果
网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
做企业网站制作流程,企业网站制作基本流程有哪些?
香港服务器选型指南:免备案配置与高效建站方案解析
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
建站中国官网:模板定制+SEO优化+建站流程一站式指南
建站主机核心功能解析:服务器选择与网站搭建流程指南
如何通过远程VPS快速搭建个人网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。