JSONP和@CrossOrigin实现跨域

跨域:当前URL的协议、域名、端口号中的任意一个与请求的URL不同即为跨域。

方法1,ajax jsonp

<body>
<button id="query" onclick="query()" type="button">查询</button>
</body>
<script type="text/javascript">
	function query(){
		$.ajax({
			url: "http://localhost:8082/selectUser",//访问的url
			data: {a:12312312},//传递的参数
			type:"get",//post,或者get都行
			dataType: "jsonp", //返回类型
			jsonp:"callback",//传递到controller的参数名--回调方法callback=xxx
			jsonpCallback: "jsonhandle",//传递到controller的参数名的值--xxx=jsonhandle
			success: function(result){
				console.log(result)
			},
			error:function(){
				console.log("查询出现错误。");
			}
			
		});
	}
	function jsonhandle(data){//回调方法具体
		alert(data);
	}
</script>

 

controller

@Controller
public class CorController {
	@RequestMapping(value="/selectUser")
	@ResponseBody
	public String queryUser(String callback) {
//		return "jsonhandle("+998+")";//都行。
		System.out.println(callback);//jsonhandle
		return callback+"("+998+")";
	}
}

 

方法2,@CrossOrigin

ajax

<script type="text/javascript">
	function query(){
		$.ajax({
			url: "http://localhost:8082/selectUser",//访问的url
			dataType: "json", //返回类型
			type:"get",
			success: function(result){
				console.log(result)
			}
		});
	}
</script>

controller

@Controller
public class CroController {
	@RequestMapping(value="/selectUser")
	@ResponseBody
	@CrossOrigin//跨域注解,可以作用在方法上,也可在类上。
	public String queryUser() {
		return "998";
	}
}

其他方法没试g...

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值