java跨域问题

本文介绍了一种解决前端跨域问题的方法,通过使用JSONP实现前后端分离项目的跨域数据请求。前端使用jQuery的ajax方法设置dataType为jsonp,并指定callback参数;后端则根据请求中的callback参数返回jsonp格式的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现在有需求是这样的:

     项目前后端分离,分别使用不同的服务器,前端使用ajax访问后端的方法时出现了跨域问题,以下是解决方法

前端:

 $.ajax({  
        type : "get",  
        async:false,  
        url : "",  
        dataType : "jsonp",//数据类型为jsonp  
        jsonp: "jsonpCallback",//服务端用于接收callback调用的function名的参数  
        success : function(data){  
            $("#showcontent").text("Result:"+data.result)  
        },  
        error:function(){  
            alert('fail');  
        }  
    });   

后端---原来的方式(json)

	net.sf.json.JSONArray jsonArray = null;
		try {
			jsonArray = net.sf.json.JSONArray.fromObject(treeList);
		} catch (Exception e) {
			e.printStackTrace();
		}
		if (jsonArray != null) {
			PrintWriter writer = response.getWriter();
			writer.print(jsonArray);
		}				

现在的后端(jsonP)

	if (jsonArray != null) {
				json2jsonP(response, request, jsonArray);
				PrintWriter out = response.getWriter();    
				String jsonpCallback = request.getParameter("callback");//客户端请求参数  
		        out.println(jsonpCallback+"("+jsonArray.toString()+")");//返回jsonp格式数据  
		        out.flush();  
		        out.close();
			}				

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值