DRF解决跨域问题

跨域CORS:前端与后端分处不同的域名,我们需要为后端添加跨域访问的支持。

我们使用CORS来解决后端对跨域访问的支持。

使用django-cors-headers扩展,参考文档:https://github.com/ottoyiu/django-cors-headers/

安装:pip install django-cors-headers

INSTALLED_APPS = (
...
'corsheaders', #添加应用
...
)

MIDDLEWARE = [
'corsheaders.middleware.CorsMiddleware', #中间层设置
...
]

CORS_ORIGIN_ALLOW_ALL = True # 跨域问题

CORS_ALLOW_CREDENTIALS = True # 允许携带cookie

CORS_ORIGIN_WHITELIST = (
'http://127.0.0.1:8000',
'http://api.gitee.com:8000',
)

CORS_ALLOW_METHODS = (
'DELETE',
'GET',
'OPTIONS',
'PATCH',
'POST',
'PUT',
'VIEW',
)
CORS_ALLOW_HEADERS = [
'*',
'dnt',
'source',
'origin',
'Pragma',
'accept',
'user-agent',
'x-csrftoken',
'X_FILENAME',
'content-type',
'authorization',
'authentication',
'XMLHttpRequest',
'accept-encoding',
"x-requested-with",
]

凡是出现在白名单中的域名,都可以访问后端接口
CORS_ALLOW_CREDENTIALS 指明在跨域访问中,后端是否支持对cookie的操作。

posted @ 2022-05-17 17:11  博客萨斯州  阅读(253)  评论(0编辑  收藏  举报