Django的拾遗

简介: django中设置返回的状态码和头部信息下面先给出我工作中使用到的代码: response = ReturnJson(data, status=401).

django中设置返回的状态码和头部信息

下面先给出我工作中使用到的代码:

        response = ReturnJson(data, status=401).get()
        return response

其中,ReturnJson是自己定义的类,用户返回json格式,做接口使用的.

from django.http import JsonResponse

class ReturnJson(object):
    def __init__(self, data, status=None):
        # status = status是设置返回的状态码
        self.response = JsonResponse(data, safe=False, status=status)
        # 设置返回的头部信息,下面是解决跨域API的问题
        self.response['Access-Control-Allow-Origin'] = 'http://local.adx.com'
        self.response['Access-Control-Allow-Credentials'] = 'true'
        self.response['Access-Control-Allow-Headers'] = 'Access-Control-Allow-Headers, Origin,Accept, X-Requested-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers, Access-Control-Allow-Credentials'

    def get(self):
        return self.response

上面的JsonResponse是继承于HttpResponseBase(多层继承)

class HttpResponseBase(six.Iterator):
    status_code = 200 # 默认 200

    # 初始化实例函数中,有status,下面的对象都是放在 **kwgs中了.
    def __init__(self, content_type=None, status=None, reason=None, charset=None):
        self._headers = {}
        self._closable_objects = []
        # This parameter is set by the handler. It's necessary to preserve the
        # historical behavior of request_finished.
        self._handler_class = None
        self.cookies = SimpleCookie()
        self.closed = False
        if status is not None:
            self.status_code = status
        self._reason_phrase = reason
        self._charset = charset
        if content_type is None:
            content_type = '%s; charset=%s' % (settings.DEFAULT_CONTENT_TYPE,
                                               self.charset)
        self['Content-Type'] = content_type

剔除CSRF_token对单个的post表单的限制

背景知识

# django的中间件
'django.middleware.csrf.CsrfViewMiddleware',  

设置好了,一般出错如图:

csrf_token报错
# 导入装饰器
from django.views.decorators.csrf import csrf_exempt

@csrf_exempt
@login_required(login_url="/api/user/login/")
def add(request):
    name = request.POST.get('name')  # 加入判断是否为空
    password = request.POST.get('password')

上面赠送了一个装饰器 @login_required()

下期预告

  django验证码
目录
相关文章
|
缓存 JavaScript 前端开发
vue2.0+vue3.0资料(尚硅谷)(五)
vue2.0+vue3.0资料(尚硅谷)
366 0
|
负载均衡 算法 应用服务中间件
Nginx系列教程(08) - Upstream Server 负载均衡
Nginx系列教程(08) - Upstream Server 负载均衡
1112 0
|
12月前
|
Java API Spring
springboot学习七:Spring Boot2.x 拦截器基础入门&实战项目场景实现
这篇文章是关于Spring Boot 2.x中拦截器的入门教程和实战项目场景实现的详细指南。
240 0
springboot学习七:Spring Boot2.x 拦截器基础入门&实战项目场景实现
|
存储 运维 数据挖掘
Python列表中每个元素前面连续重复次数的数列统计
Python列表中每个元素前面连续重复次数的数列统计
152 1
【Unity3D开发小游戏】Unity3D零基础一步一步教你制作跑酷类游戏
【Unity3D开发小游戏】Unity3D零基础一步一步教你制作跑酷类游戏
|
存储 缓存 流计算
uvc驱动ioctl分析上
uvc驱动ioctl分析上
345 0
|
人工智能 自动驾驶 安全
破壁人AI百度:科技公司反内卷的典型样本
互联网整个行业都在陷入被动且尴尬的局面。去年开始流行的“内卷”一词,恰如其分的描述了互联网的现状,比如抖音开始做外卖,微信强推视频号,一直硝烟弥漫的电商市场,更是激战在社区团购上。
|
Oracle 关系型数据库 数据库连接
Kingbase国产化数据库数据迁移:oracle11g数据库转库人大金仓数据库实例演示
Kingbase国产化数据库数据迁移:oracle11g数据库转库人大金仓数据库实例演示
644 0
|
Web App开发 前端开发 JavaScript
前端开发必备的7个工具
前端开发需要使用一些工具来提高效率和质量,但是选择哪些工具可以有很多选择。在这篇文章中,我们将介绍前端开发中必备的7个工具,它们将使你的开发体验更加高效和愉悦。
1113 0