javascript 跨域问题以及解决办法

前端之家收集整理的这篇文章主要介绍了javascript 跨域问题以及解决办法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

javascript 跨域问题以及解决办法

什么是跨域问题?

跨域这个问题是由于浏览器的同源策略引起的,请求的URL地址,必须与浏览器的URL是相同协议、相同域名、相同端口的,否则是不允许访问的

浏览器URL 要访问的URL 结果

解决办法

凡是拥有src属性标签都可以跨域,比如script、img、iframe标签

JSONP

JSONP就是应用了script标签,JSONP的全称是JSON With Padding,JSONP由两部分组成,回掉函数和数据,回掉函数就是当响应到来时应该在页面调用函数,回掉函数的名字是在请求中指定的,而数据就是传入回掉函数的JSON数据

例子:

<Meta charset="UTF-8"> Insert title here

<script type="text/javascript">
function jsonCallback(data){
alert(data);
};
var url = "http://localhost:8888/test?callback=jsonCallback";
var script = document.createElement('script');
script.type = "text/javascript";
script.setAttribute('src',url);
document.getElementsByTagName('head')[0].appendChild(script);

缺点:确认JSONP请求是否失败并不容易

​ 安全性的问题,JSONP是从其他域加载代码执行,所以要确定其可靠性

以上就是javascript 跨域问题以及解决办法的讲解,大家如果 有疑问可以留言讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持

原文链接:https://www.f2er.com/js/37797.html

猜你在找的JavaScript相关文章