• Django django-cors-headers实现防跨域


    安装

    pip install django-cors-headers

    注册

    1 INSTALLED_APPS = (
    2   'corsheaders',
    3 )

    添加中间件

     1 MIDDLEWARE = [
     2     'django.middleware.security.SecurityMiddleware',
     3     'django.contrib.sessions.middleware.SessionMiddleware',
     4     'django.middleware.csrf.CsrfViewMiddleware',
     5     'django.contrib.auth.middleware.AuthenticationMiddleware',
     6     'django.contrib.messages.middleware.MessageMiddleware',
     7     'django.middleware.clickjacking.XFrameOptionsMiddleware',
     8     'corsheaders.middleware.CorsMiddleware',  # 按顺序
     9     'django.middleware.common.CommonMiddleware',  # 按顺序
    10 ]

    CorsMiddleware应该放置得尽可能高,特别是在可以产生响应的任何中间件之前, 如Django CommonMiddleware或Whitenoise WhiteNoiseMiddleware。 如果以前没有,则无法将CORS头添加到这些响应中。

    配置白名单

     1 CORS_ALLOW_CREDENTIALS = True#允许携带cookie
     2 CORS_ORIGIN_ALLOW_ALL = True
     3 CORS_ORIGIN_WHITELIST = ( '*')#跨域增加忽略
     4 CORS_ALLOW_METHODS = ( 'DELETE', 'GET', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'VIEW', )
     5 #允许的请求头
     6 CORS_ALLOW_HEADERS = (
     7     'XMLHttpRequest',
     8     'X_FILENAME',
     9     'accept-encoding',
    10     'authorization',
    11     'content-type',
    12     'dnt',
    13     'origin',
    14     'user-agent',
    15     'x-csrftoken',
    16     'x-requested-with',
    17     'Pragma',
    18 )

    前端项目设置请求头记得添加到CORS_ALLOW_HEADERS

                                                                  

  • 相关阅读:
    把程序的定义与实现部分用头文件与源文件分开
    简单控件的应用(二)—学生管理系统
    Java基础14
    创建插入符、输出不同效果的文字
    Java基础12
    简单控件的应用(一)—prj计算器
    简单的Win 32 Application
    最简单的音乐播放器
    消息处理初步
    基于MFC,在非客户区与客户区利用CButon类创建button
  • 原文地址:https://www.cnblogs.com/daidechong/p/11236133.html
Copyright © 2020-2023  润新知