使用Nginx 反向代理来避免 ajax 跨域请求的方法
服务器上nginx+tomcat,其中nginx监听80端口,tomcat监听8080端口。
因为对前端不熟悉,以为用ajax就可以不需要callback,然而前端的同学说不跨域的情况下才不需要callback,让我在返回的json里加上。可是我刚刚学会了最基本的spring-mvc用法,根本不知道怎么加上callback
网上到时找到一些可行的代码,差不多这个样子:
@RequestMapping(method=RequestMethod.GET,value="getProjectStatusList",produces="text/html;charset=UTF-8")
@ResponseBody
publicStringgetProjectStatusList(HttpServletRequestrequest,
HttpServletResponseresponse){
Map<String,Object>map=newHashMap<String,Object>();
try{
Stringcallback=request.getParameter("callback");
//System.out.println("token:"+request.getHeader("token"));
List<String>list=ss.getProjectStatusList();
map.put("status","success");
map.put("data",list);
ObjectMappermapper=newObjectMapper();
//这个拼接是重点。。。
Stringresult=callback+"("+mapper.writeValueAsString(map)+")";
//Stringresult=mapper.writeValueAsString(map);
returnresult;
}catch(Exceptione){
JSONObjectjo=newJSONObject();
jo.put("status","fail");
jo.put("data",e.getMessage());
returnjo.toString();
}
}
然而这样改动对我来说简直是伤筋动骨,因为我有太多的URL映射,修改的成本太大。
所以机智的我想到了nginx,这家伙不就是拿来搞反向代理的吗?真是机智如我
有了这个思路,做起来就简单了。直接在监听80端口的server中添加一个location:
location/myApp{
proxy_passhttp://localhost:8080/myApp;
}
重新加载nginx:
{NGINX_HOME}/sbin/nginx-sreload
然后就把之前http://site:8080/myApp的跨域请求变成了http://site/myApp的非跨域请求。
以上所述是小编给大家介绍的使用Nginx反向代理来避免ajax跨域请求的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!