一个库彻底解决django跨域的问题

首先需要用pip引用一个三方库corsheader:

pip install django-cors-headers

然后修改django项目中的配置:

INSTALLED_APPS = [
	···
	···
    'corsheaders', //增加这一行
]
MIDDLEWARE = [
    ···
    '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',
)

前端调接口的时候可能会遇到参数被浏览器拦截的问题!

这个原因我遇到的是context-type的格式,以前的项目都是application/json,而这个项目得用text/html;charset=utf-8

猜你喜欢

转载自blog.csdn.net/weixin_46304253/article/details/109288945
今日推荐