欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

谈谈对javacript跨域的理解

程序员文章站 2022-03-16 11:32:09
谈谈对javacript跨域的理解 javacript处于安全方面的考虑,不允许跨域调用其他页面的对象,什么是跨域呢?简单的理解就是因为javascript同源策略的限制,a...

谈谈对javacript跨域的理解

谈谈对javacript跨域的理解

javacript处于安全方面的考虑,不允许跨域调用其他页面的对象,什么是跨域呢?简单的理解就是因为javascript同源策略的限制,a.com域名下的js无法操作b.com或者是c.a.com域名下的对象

谈谈对javacript跨域的理解

谈谈对javacript跨域的理解

处理跨域的方法一: 代理(后台技术)

通过在同域名的web服务器端创建一个代理:

背景服务器(域名:www.beijing.com)

上海服务器(域名:www.shanghai.com)

比如在北京的web服务器的后台

(www.beijing.com/proxy-shanghaiservice.php)来调用上海服务器(www.shanghai.com/server.php)的服务,然后再把响应的结果返回给前端,这样前端调用北京同域名的服务就和调用上海的服务效果相同了

处理跨域的方法二:jsonp(不支持post请求)

jsonp可用于解决主流的跨域数据访问的问题

在www.aaa.com 的页面中:(a域名声明)

<script>
function jsonp(json){
alert(json["name"]);
}
</script>
<script src="https://www.bbb.com/jsonp.js"></script>

在www.bbb.com页面中:(b域名调用)

jsonp({'name':'小明','age':24})

处理跨域方法三:xhr2

html5提供xmlhttprequest level2已经实现了跨域访问以及其他的一些新功能

ie10以下的版本都不支持

在服务器端做一些小小的改造即可:

header('access-control-allow-origin:*');

header('access-control-allow-methods:post,get');