当前位置: 移动技术网 > IT编程>开发语言>JavaScript > javascript 跨域问题以及解决办法

javascript 跨域问题以及解决办法

2017年12月12日  | 移动技术网IT编程  | 我要评论
javascript 跨域问题以及解决办法 什么是跨域问题? 跨域这个问题是由于浏览器的同源策略引起的,请求的url地址,必须与浏览器的url是相同协议、相同域名、相同

javascript 跨域问题以及解决办法

什么是跨域问题?

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

浏览器url 要访问的url 结果
http://www.123.com/index http://www.123.com/server 成功
http://www.123.com/index http://www.456.com/server 域名不相同,跨域
http://www.123.com:8080/index http://www.123.com:8888/index.htm 端口不同,跨域
http://www.123.com/index https://www.123.com/index 协议不同,跨域

解决办法

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

jsonp

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

例子:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>insert title here</title>

<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);
</script>
</head>
<body>
</body>
</html>

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

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

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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网