「Django」rest_framework学习系列-API访问跨域问题

本文介绍了一种通过在Django项目中使用中间件来解决API数据访问跨域问题的方法。主要步骤包括在API目录下创建并配置中间件,重写响应处理函数以添加跨域响应头,以及在settings.py中注册中间件。
摘要由CSDN通过智能技术生成

#以中间件方式解决API数据访问跨域问题
1.API下新建文件夹下写PY文件
a.引入内置类继承:

from django.middleware.common import MiddlewareMixin

class CORSMiddleware(MiddlewareMixin):
    def process_response(self,request,response):
        #添加响应头
        #允许你的域名来获取我的数据,'*'也可以单独设置
        response['Access-Control-Allow-Origin'] = '*'

        #允许携带Content-Type请求头
        response['Access-Control-Allow-Headers'] = 'Content-Type'

        #如果PUT或者别的请求形式报错
        response['Access-Control-Allow-Methods'] = 'put,'

        return response
View Code

b.重写继承类:

可以引入,也可以如下重写方法
class MiddlewareMixin:
    def __init__(self, get_response=None):
        self.get_response = get_response
        super().__init__()

    def __call__(self, request):
        response = None
        if hasattr(self, 'process_request'):
            response = self.process_request(request)
            response = response or self.get_response(request)
        if hasattr(self, 'process_response'):
            response = self.process_response(request, response)
        return response

class CORSMiddleware(MiddlewareMixin):
    def process_response(self,request,response):
    #添加响应头
    #允许你的域名来获取我的数据,'*'也可以单独设置
    response['Access-Control-Allow-Origin'] = '*'
    #允许携带Content-Type请求头,如果允许别的请求头加入,写在后面,如k1
    response['Access-Control-Allow-Headers'] = 'Content-Type,k1'

    return response    
View Code

2.settings中间件添加

MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
# 'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'middleware.CorsMiddleware.CORSMiddleware'#引入处理跨域的类
]
View Code

 

转载于:https://www.cnblogs.com/wrxblog/p/10416291.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值