跨域请求的几种解决方法

跨域请求

跨域请求:两个不同域名之间的通讯。

Ajax受到浏览器的限制(安全性考虑)不允许跨域通信。

<script>
var req=new XMLHttpRequest();
req.open('get','http://phpmyadmin.com/test/home.js');   //报错
req.send();
</script>

在这里插入图片描述

默认情况下浏览器采用同源策略:一个域下面的JS只能请求同一个域下面的文档内容,不能跨域请求。

1.1 解决方法一:src属性

使用标签的src属性,src属性是没有同源的限制的

<img src='http://www.baidu.com/tu1.jpg' />
<script src='http://phpmyadmin.com/test/home.js'></script>
1.2 解决方法二:PHP代理

在这里插入图片描述

A客户端

<script>
var req=new XMLHttpRequest();
req.open('post','./6-demo.php');
req.onreadystatechange=function(){
	if(req.readyState==4 && req.status==200){
		alert(req.responseText);
	}
}
req.send();
</script>

A服务器

<?php
echo file_get_contents('http://phpmyadmin.com/test/test.php');

B服务器

<?php
echo '锄禾日当午';

小结:客户端有同源策略,服务器没有同源策略,我们可以使用服务器作为代理去跨域请求。

A服务器(http://www.php.com)

B服务器(http://phpmyadmin.com

1.3 解决方法三:jsonp

jsonp=json+动态script。是一种非官方协议,为了解决JS的跨域请求

通过<script>的src属性引入跨域文件从而携带数据实现了数据的跨域访问。

代码实现

客户端代码(www.php.com

<body>
<script>
function fun(data){
	alert(data);
}
window.onload=function(){
	document.getElementById('btn').onclick=function(){
		var script=document.createElement('script');
		script.src='http://phpmyadmin.com/test/test.php?fn=fun'; //动态添加script的src属性
		document.body.appendChild(script);
	}
}
</script>
<input type="button" value="确定" id='btn'>
</body>

PHP代码(http://phpmyadmin.com

<?php
$stu=array('tom','berry');
$data=json_encode($stu);
echo "{$_GET['fn']}($data)";    //拼接函数的调用

小结:

1、通过动态的添加script的src属性

2、传递的函数名和客户端定义的函数名要一致

3、跨域的服务器返回的是调用函数的形式

思考:json与jsonp的区别?

答: json是一种通用的数据交换格式,主要实现数据的传输与储存。

      jsonp是一种非官方协议,为了解决JS的跨域请求问题。
1.4 解决方法四:CORS实现跨域

设置允许接受的源

header('Access-Control-Allow-Origin:http://www.php.com');   //允许php.com访问

CORS(Cross-Origin Resource Sharing)跨源资源共享:服务器在响应头中告知浏览器那些域请求限制,哪些域请求接受。

客户端代码(http://www.php.com

<body>
<script>
window.onload=function(){
	document.getElementById('btn').onclick=function(){
		var req=new XMLHttpRequest();
		req.open('post','http://phpmyadmin.com/test/test.php');
		req.onreadystatechange=function(){
			if(req.readyState==4)
				alert(req.responseText);
		}
		req.send()
	}
}
</script>
<input type="button" value="确定" id='btn'>
</body>

服务器端代码(http://phpmyadmin.com

header('Access-Control-Allow-Origin:*');    //允许所有的域名访问
echo 'i am a boy';
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
解决 Geoserver 请求跨域的几种思路如下: 1. 使用代理服务器:可以使用一个代理服务器来处理跨域请求代理服务器可以在客户端和 Geoserver 之间充当中间人,将客户端的请求转发给 Geoserver,并将 Geoserver 的响应返回给客户端。这种方法可以通过配置代理服务器来实现跨域请求,但是会增加服务器的负担。 2. 配置 Geoserver:Geoserver 本身支持 CORS(Cross-Origin Resource Sharing),可以通过在 Geoserver 的 web.xml 文件中配置 CORS 的参数来实现跨域请求。可以通过添加以下代码来启用 CORS: ``` <filter> <filter-name>CorsFilter</filter-name> <filter-class>org.apache.catalina.filters.CorsFilter</filter-class> <init-param> <param-name>cors.allowed.origins</param-name> <param-value>*</param-value> </init-param> </filter> <filter-mapping> <filter-name>CorsFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 3. 使用 JSONPJSONP(JSON with Padding)是一种跨域请求解决方案。它通过在请求中添加一个回调函数名,让服务器返回一个 JavaScript 函数调用,从而绕过浏览器的跨域限制。如果 Geoserver 支持返回 JSONP 格式数据,可以通过在客户端使用 JSONP 的方式来实现跨域请求。 4. 使用 WebSocket:WebSocket 是一种支持双向通信的网络协议,可以在客户端和服务器之间建立一个持久化的连接。如果 Geoserver 支持 WebSocket ,可以通过 WebSocket 的方式来实现跨域请求。这种方法相对于其他方法更加灵活,但需要客户端和服务器都支持 WebSocket 协议。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值