因为开发模式为先后端分离式开发,故而一般状况下,前端和后端可能运行不一样的ip或者port下,致使出现跨域问题,故而单独说明
跨域是指一个域下的文档或脚本试图去请求另外一个域下的资源,这里跨域是广义的。
其实咱们一般所说的跨域是狭义的,是由浏览器同源策略限制的一类请求场景。前端
什么是同源策略?django
同源策略/SOP(Same origin policy)是一种约定,由Netscape公司1995年引入浏览器,它是浏览器最核心也最基本的安全功能,若是缺乏了同源策略,浏览器很容易受到XSS、CSFR等攻击。所谓同源是指"协议+域名+端口"三者相同,即使两个不一样的域名指向同一个ip地址,也非同源。segmentfault
同源策略限制如下几种行为:后端
跨域错误浏览器会在控制台中出现以下错误:
报错信息以下:api
Access to XMLHttpRequest at ' http://127.0.0.1:8000/api/test/' from origin ' http://127.0.0.1:3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
翻译过来便是:从源地址 http://127.0.0.1:3000 发起的到http://127.0.0.1:8000/api/test/ 的XMLHttpRequest访问违反了同源策略:由于在请求头中没有Access-Control-Allow-Origin的值跨域
参考博客浏览器
既然跨域是由于不一样源,那我同源不就完事儿了,可是后端请求地址不可能改变,因此能够在前端和后端的中间加一层代理,前端经过代理访问后端。
在Vue-cli工具中已经提供了代理的功能,只须要配置便可。
在根目录下的config/index.js文件中有以下配置项:安全
proxyTable: { '/': { target: 'http://127.0.0.1:8000/', changeOrigin: true, pathRewrite: { '^/api': '' } } },
参考博客服务器
后端出于安全考虑,也会对于跨域有限制,解决方法以下:app
安装django-cors-headers
$ pip install django-cors-headers
配置settings.py文件
INSTALLED_APPS = [ ... 'corsheaders', ... ] MIDDLEWARE_CLASSES = ( ... 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', # 注意顺序 ... ) #跨域增长忽略 CORS_ALLOW_CREDENTIALS = True CORS_ORIGIN_ALLOW_ALL = True CORS_ORIGIN_WHITELIST = ( '*' ) CORS_ALLOW_METHODS = ( 'DELETE', 'GET', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'VIEW', ) CORS_ALLOW_HEADERS = ( 'XMLHttpRequest', 'X_FILENAME', 'accept-encoding', 'authorization', 'content-type', 'dnt', 'origin', 'user-agent', 'x-csrftoken', 'x-requested-with', 'Pragma', )