加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

AJAX跨域的解决方案

发布时间:2020-12-16 00:40:33 所属栏目:百科 来源:网络整理
导读:这2天整合安卓项目的时候,遇到跨域的问题。 Mark一下解决方案 首先修改远程服务端的输出代码: @RequestMapping(value="backpackItems",method=RequestMethod.GET)public @ResponseBody void getItemsList(HttpServletRequest req,HttpServletResponse res,

这2天整合安卓项目的时候,遇到跨域的问题。

Mark一下解决方案

首先修改远程服务端的输出代码:

	@RequestMapping(value="backpackItems",method=RequestMethod.GET)
	public @ResponseBody void getItemsList(HttpServletRequest req,HttpServletResponse res,@RequestParam String player,@RequestParam String callback){
		List<AuctionItem> list = AuctionItemDao.findInBackpack(player);
		try {
			DataOutputStream dos = new DataOutputStream(res.getOutputStream());
			dos.write((callback + new Gson().toJson(list)).getBytes());
			dos.flush();
			dos.close();
		} catch (IOException e) {
			e.printStackTrace();
		}
		//return callback + new Gson().toJson(list);  //测试失败
	}	



在JS代码片段中使用:
function cdajxa(url,callback){
	var Website = 'http://127.0.0.1:8080/AuctionWeb/';
	var script = document.createElement("script");
	window.cdajxa_cid={};
	var key ="l_lcn_"+Math.round(Math.random()*10000);
	cdajxa_cid[key]=null;
	script.src = Website+url+"&callback=cdajxa_cid['"+key+"']=&rnd="+Math.random();
	document.body.appendChild(_script);
	script.onload = script.onreadystatechange = function(){
		if(!this.readyState || this.readyState=="loaded" || this.readyState=="complete"){
			//这里可以修改,但是必须调用callback回调函数
			//自定义是否需要返回值,可根据情况自定义回调函数的参数
			var html = callback(key,cdajxa_cid[key]);
			$("#auction_net_ajax_"+key).html(html);
		}
	};
	//这里可以修改,可根据情况是否需要返回值
	return "<div id='auction_net_ajax_"+key+"'>数据加载中....</div>";
}

应当注意JS中callback参数值后面的等号的特别意义

//=================================//

数据请求为GET

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读