什么是跨域
跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript实施的安全限制。
同源策略限制了以下行为
- Cookie、LocalStorage 和 IndexDB 无法读取
- DOM 和 JS 对象无法获取
- Ajax请求发送不出去
什么是同源策略
同源策略是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源。
如果两个页面的协议,端口和域名都相同,则两个页面具有相同的源。
利用jsonp解决跨域
JavaScript代码
//要在请求php文件之前定义好这个fn函数,
//如果在后面定义,返回找不到这个函数就会报错
<script>
function fn(res) {
//打印一下结果
console.log(res)
}
</script>
<script src="http://127.0.0.1/jsonp2.php"></script>
php代码
<?php
//后端准备一些数据
$name = 'kangkang';
$age = 20;
//输出有个可执行代码
echo "fn({name:'$name',age:$age})"
?>
这种解决方式只能发送GET请求
当然,解决跨域方法还有其他的,我暂时就不举例子了,(暂时就会这么点)最后祝大家每天都有进步,BUG距离大家越来越远