摘要:遇到了前端跨域请求的问题。所以机智的我想到了,这家伙不就是拿来搞反向代理的吗真是机智如我有了这个思路,做起来就简单了。直接在监听端口的中添加一个重新加载然后就把之前的跨域请求变成了的非跨域请求。
在慕课网上看了高并发的课程,准备用spring+Mybaits来开发新的项目。遇到了前端跨域请求的问题。
服务器上nginx+tomcat,其中nginx监听80端口,tomcat监听8080端口。
因为对前端不熟悉,以为用ajax就可以不需要callback,然而前端的同学说不跨域的情况下才不需要callback,让我在返回的json里加上。可是我刚刚学会了最基本的spring-mvc用法,根本不知道怎么加上callback
网上到时找到一些可行的代码,差不多这个样子:
来源:http://quarterlifeforjava.ite...
@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的非跨域请求。
好吧,都是我猜的,等前端同学来验证我的想法了
忘了更新了
下午实验课自己写了个ajax请求试了下,这个思路是没有问题的
$.ajax({url : "/myApp/list", async : true}).success( function (data) { console.log(data); });
打印结果:
Object {data: Array[8], success: true, errorMsg: null}
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/39305.html
摘要:三反向代理解决的原理将安装在本地,然后将项目部署于下,这样访问本地项目时用本地项目即可访问。这样浏览器之间的请求完全满足浏览器域名协议端口相同的同源策略,可在不改变后台接口的情况下避免跨域问题。 一、问题背景说明: 编写移动前端页面时需要访问后台系统接口。前端项目在本地(个人办公电脑)开发,后台接口存放后生产的后台服务器,本地的ajax请求无法直接访问后台接口,也就是遇到了跨域问题...
摘要:三反向代理解决的原理将安装在本地,然后将项目部署于下,这样访问本地项目时用本地项目即可访问。这样浏览器之间的请求完全满足浏览器域名协议端口相同的同源策略,可在不改变后台接口的情况下避免跨域问题。 一、问题背景说明: 编写移动前端页面时需要访问后台系统接口。前端项目在本地(个人办公电脑)开发,后台接口存放后生产的后台服务器,本地的ajax请求无法直接访问后台接口,也就是遇到了跨域问题...
阅读 1644·2023-04-26 02:11
阅读 2985·2023-04-25 16:18
阅读 3717·2021-09-06 15:00
阅读 2636·2019-08-30 15:55
阅读 1938·2019-08-30 13:20
阅读 2054·2019-08-26 18:36
阅读 3129·2019-08-26 11:40
阅读 2543·2019-08-26 10:11