使用Nginx 反向代理来避免 ajax 跨域请求的方法
程序员文章站
2023-02-21 21:53:05
服务器上 nginx + tomcat ,其中 nginx 监听 80 端口, tomcat 监听 8080 端口。
因为对前端不熟悉,以为用 ajax 就可以不需要 c...
服务器上 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){ map<string,object> map = new hashmap<string,object>(); try{ string callback = request.getparameter("callback"); //system.out.println("token:"+request.getheader("token")); list<string> 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 跨域请求的方法,希望对大家有所帮助
上一篇: 电饭煲卤鸡腿需要多长时间才能卤好
下一篇: 详解vue-router基本使用