javascript 跨域问题以及解决办法
程序员文章站
2022-05-26 08:29:24
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 跨域问题以及解决办法的讲解,大家如果 有疑问可以留言讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
下一篇: iscroll.js滚动加载实例详解