app跨域请求

<pre name="code" class="javascript">		function handleErr(xhr,type,errorThrown){
			if(type == 'timeout'){
	            alert('连接服务器超时,请检查网络是否畅通!');
	        }else if(type == 'parsererror'){
	            alert('解析返回结果失败!');
	        }else if(type == 'error'){

	               alert('连接服务器失败!');


	        }else{
	            alert('未知异常');
	        }
		}


 
function getData(murl, mdata,successCallback, errCallback) {
$.ajax({
	type : "GET",
	timeout:150000,
	url : getIP()+murl,
	dataType : "jsonp",
	jsonpCallback:"callback",
	data : {
		'requestUser':"{'ID':'"+getUser()+"','Password':'"+getPassword()+"'}",
		'data' : mdata
	},
	success : function(e) {
		successCallback(e);
	},
	error:function(XMLHttpRequest,textStatus,errorThrown) {
	if(errCallback) errCallback(XMLHttpRequest,textStatus,errorThrown);
	}
});
}

后台要接收前台提交过来的"callback",然后再返回到前台。如果直接返回json数据,前台会报缺少冒号。

<pre name="code" class="java">public class HandlerResponeJson {
	public static String handle(String func,String data){
		return func + "(" + data + ")";
	}
}



<pre name="code" class="java">	@ResponseBody
	@RequestMapping(value="/updatepassword",produces = "application/json;charset=UTF-8")
	public String updatePassword(HttpServletRequest request,@RequestParam("callback") String callback,Map<String, Object> map) {
		Message<Object> msg = new Message<Object>();
		
		String mdata = request.getParameter("data");
		JSONObject obj = JSON.parseObject(mdata);
		
		

		Map<String,Object> data = new HashMap<String,Object>();
		data.put("oldPwd", oldPwd);
		msg.setMsg("update success");
		msg.setObj(data);
		
		
		return HandlerResponeJson.handle(callback,JSON.toJSONString(msg));
	}


 


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值