html - 弱弱的问一个跨域的问题
问题描述
比如,同一台服务器上,网站主目录绑定到www.domain.com上,网站后台绑定到www.domain.com:8080上。
即便端口不同也会被当做跨域吧? 感觉这种情况跨域有点冤,而且POST也没有不跨域方便吧?
各位大大有什么好办法解决一下这个问题吗,能通过某些设置而让网站和后台之间不跨域吗?这种网站和后台分离的方式迟早要面对跨域的问题,是吗?
问题解答
回答1:跨站的解决方案很多,常见的是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
回答2:端口不同本来就是不同的站点,站点与站点之间就是跨域啊!通过分开前后台,是可以让网站比较安全,也可以分端维护,我觉得没必要去用前端跨域请求后台,这样会把后台曝露了,而且程序设计上也不应该通过前端跨域取数据吧!除非你数据库是文件型数据库Access或sqlite这类,那就是你设计上的问题,请求数据只需要有数据连接就可以的了。没必要跨域。
相关文章:
1. docker绑定了nginx端口 外部访问不到2. python - 使用pandas的resample报错3. android - 类似于微信朋友圈图片这样的是在listview中嵌套gridview还是动态加入多个imageview呢?4. java - xml 传输数据如何处理更好5. docker-machine添加一个已有的docker主机问题6. 安装完wordpress 后出现这个错误7. 从git上下载的laravel项目不能用8. phpstudy v8打开数据库就出错,而phpstudy 2018不会9. MySQL 书籍推荐10. node.js - session怎么存到cookie,然后服务器重启后还能获取。数据库不用mongodb或redis,数据库是mysql

网公网安备