Django+vue跨域问题解决

39次阅读

共计 1675 个字符,预计需要花费 5 分钟才能阅读完成。

跨域
由于开发模式为前后端分离式开发,故而通常情况下,前端和后端可能运行不同的 ip 或者 port 下,导致出现跨域问题,故而单独说明
什么是跨域
跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。其实我们通常所说的跨域是狭义的,是由浏览器同源策略限制的一类请求场景。
什么是同源策略?
同源策略 /SOP(Same origin policy)是一种约定,由 Netscape 公司 1995 年引入浏览器,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到 XSS、CSFR 等攻击。所谓同源是指 ” 协议 + 域名 + 端口 ” 三者相同,即便两个不同的域名指向同一个 ip 地址,也非同源。
同源策略限制以下几种行为:

Cookie、LocalStorage 和 IndexDB 无法读取
DOM 和 Js 对象无法获得
AJAX 请求不能发送

跨域错误浏览器会在控制台中出现如下错误:报错信息如下:
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’: ”
}
}
},

‘/’ 表示以 ’/'(即所有的路径) 开头的路径均需要代理,
target: 代理的目标服务器地址(即后端服务器地址)为 ‘http://127.0.0.1:8000/’,
changeOrigin,为修改源:修改请求中的源地址
pathReWrite:URL 路径重写,对于以 ’/api’ 开头的路径将 ’/api’ 替换为 ”

后端解决跨域
参考博客
后端出于安全考虑,也会对于跨域有限制,解决方法如下:
安装 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’,
)

正文完
 0