比如,同一台服务器上,网站主目录绑定到www.domain.com上,网站后台绑定到www.domain.com:8080上。
即便端口不同也会被当做跨域吧? 感觉这种情况跨域有点冤,而且POST也没有不跨域方便吧?
各位大大有什么好办法解决一下这个问题吗,能通过某些设置而让网站和后台之间不跨域吗?这种网站和后台分离的方式迟早要面对跨域的问题,是吗?
跨站的解决方案很多,常见的是JSONP,代理转发,还有就是HTLM5的Allow Orgin允许跨站访问的新功能。
你这种情况,建议在网站的Ngingx设置个代理,转发到网站后台就可以了,配置大概是这样的:
upstream backend { server backend1.example.com:8080; } server { location /api { proxy_pass http://backend; } }
在前端页面,通过ajax访问的地址为:http://www.example.com/api/xxx
端口不同本来就是不同的站点,站点与站点之间就是跨域啊!通过分开前后台,是可以让网站比较安全,也可以分端维护,我觉得没必要去用前端跨域请求后台,这样会把后台曝露了,而且程序设计上也不应该通过前端跨域取数据吧!除非你数据库是文件型数据库Access或sqlite这类,那就是你设计上的问题,请求数据只需要有数据连接就可以的了。没必要跨域。
跨站的解决方案很多,常见的是JSONP,代理转发,还有就是HTLM5的Allow Orgin允许跨站访问的新功能。
你这种情况,建议在网站的Ngingx设置个代理,转发到网站后台就可以了,配置大概是这样的:
在前端页面,通过ajax访问的地址为:http://www.example.com/api/xxx
端口不同本来就是不同的站点,站点与站点之间就是跨域啊!通过分开前后台,是可以让网站比较安全,也可以分端维护,我觉得没必要去用前端跨域请求后台,这样会把后台曝露了,而且程序设计上也不应该通过前端跨域取数据吧!除非你数据库是文件型数据库Access或sqlite这类,那就是你设计上的问题,请求数据只需要有数据连接就可以的了。没必要跨域。