基于jQuery的ajax跨域请求,PHP作为服务器端代码

ajax实现跨域请求有两种方式:

方法一:jsonp的方式

jsonp方式的关键点在客户请求以jsonp作为数据类型,服务器端接收jsonp的回调函数,并通过回调函数进行数据的传输。具体代码如下:

客户端:

 $.ajax({
	type:"GET",
	url:"http://192.168.20.88:80/class/index.php",
	dataType:"jsonp",
	jsonp:"callback",
	jsonpCallback:"success_jsonpCallback",	
	success:function(json){
		$("#textShow").html("姓名:"+json.name+"  性别:"+json.sex);
	},
	error:function(){
		alert("fail");
	}
})

服务器端;

//    使用jsonp实现跨域传输的方式,重点在于通过callback回调函数进行传递数据
    $data=array("name"=>"张三","sex"=>"男");
    $callback=$_GET['callback'];
    echo $callback."(".json_encode($data).")";

方法二:使用CORS方式

之所以产生跨域问题是应为浏览器遵从同源策略,何为同源?所谓同源是指域名、协议、端口相同。只有在同源策略下才能够进行数据的交互。而跨域显然是不满足同源策略要求。所以为此提供了CORS方式,为要请求的目的服务器段加上header请求头便可实现客户端跨域请求。代码如下:

服务器端(PHP):

//    使用CORS进行处理跨域传输
echo "hello boy,我是通过CORS方式传输的";
// 允许 http://localhost:8080 发起的跨域请求
header("Access-Control-Allow-Origin:http://localhost:8080");

客户端:

$("#textShow").load("http://192.168.20.88:80/class/index.php"); 

jsonp的方式只支持get方式数据交互,而CORS方式可令客户端以同源策略下的各种方式请求数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值