大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍如何使用Nginx反向代理来避免ajax跨域请求,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
创新互联长期为上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为泗县企业提供专业的成都网站设计、网站建设、外贸网站建设,泗县网站改版等技术服务。拥有10余年丰富建站经验和众多成功案例,为您定制开发。服务器上 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 public String getProjectStatusList(HttpServletRequest request, HttpServletResponse response){ Mapmap = new HashMap (); try{ String callback = request.getParameter("callback"); //System.out.println("token:"+request.getHeader("token")); List list = ss.getProjectStatusList(); map.put("status", "success"); map.put("data", list); ObjectMapper mapper = new ObjectMapper(); //这个拼接是重点。。。 String result = callback+"("+mapper.writeValueAsString(map)+")"; //String result = mapper.writeValueAsString(map); return result; }catch(Exception e){ JSONObject jo = new JSONObject(); jo.put("status", "fail"); jo.put("data", e.getMessage()); return jo.toString(); } }
然而这样改动对我来说简直是伤筋动骨,因为我有太多的 URL 映射,修改的成本太大。
所以机智的我想到了 nginx ,这家伙不就是拿来搞反向代理的吗?真是机智如我
有了这个思路,做起来就简单了。直接在监听 80 端口的 server 中添加一个 location :
location /myApp { proxy_pass http://localhost:8080/myApp; }
重新加载 nginx :
{NGINX_HOME}/sbin/nginx -s reload
然后就把之前 http://site:8080/myApp 的跨域请求变成了 http://site/myApp 的非跨域请求。
以上是“如何使用Nginx反向代理来避免ajax跨域请求”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!