用angular发起http.get(),访问后端web API要数据,结果chrome报错:跨域了html
Access to XMLHttpRequest at 'http://127.0.0.1:3000/XXX'
from origin 'http://127.0.0.1:4200' has been blocked by CORS policy:
No 'Access-Control-Allow-Origin' header is present on the requested resource.
此时后端nodejs显示返回值正常。只是浏览器给拦截了。前端
参考https://www.cnblogs.com/relucent/p/4274158.htmlnode
什么是跨域web
当两个域具备相同的协议(如http), 相同的端口(如80),相同的host(如www.google.com),那么咱们就能够认为它们是相同的域(协议,域名,端口都必须相同)。chrome
跨域就指着协议,域名,端口不一致,出于安全考虑,跨域的资源之间是没法交互的docker
解决方法很简单,在服务器端的response里添加header,容许前端指定的主机访问express
具体到express 参考 https://www.cnblogs.com/ae6623/p/4433143.htmljson
注意要包括 http://,和端口号,最好把这些写在一个配置文件里,在nodejs启动时加载进来,便于在docker等容器里用的时候修改前端的IP和端口