2021-07-09 drf请求全局和局部配置 基于jwt的认证类 基于自定义User表,签发token 多方式登录

1 drf请求全局和局部配置(2星)

1 请求支持三种编码格式,urlencoded,json,formdata
2 如果不配置,默认支持三种
   'DEFAULT_PARSER_CLASSES': [
        'rest_framework.parsers.JSONParser',  # 解析application/json格式
        'rest_framework.parsers.FormParser', # 解析application/x-www-form-urlencoded
        'rest_framework.parsers.MultiPartParser' # multipart/form-data
    ]
        
        
3 全局配置,在项目的配置文件中配置
REST_FRAMEWORK = {
   
    'DEFAULT_PARSER_CLASSES': [
        # 'rest_framework.parsers.JSONParser',  # 解析application/json格式
        'rest_framework.parsers.FormParser',  # 解析application/x-www-form-urlencoded
        # 'rest_framework.parsers.MultiPartParser'  # multipart/form-data
    ]
}

4 局部配置
from rest_framework.parsers import JSONParser
class BookView(ViewSetMixin,ListAPIView,CreateAPIView):
    parser_classes = [JSONParser,]

2 基于jwt的认证类

1 重点逻辑authenticate方法中
	-取出客户端传入的token(后端自己规定,写道接口文档中过了),请求头中,请求地址。。。
    -验证jwt的签名(模块提供了)
    -通过payload得到当前登录用户对象(模块提供了)
    -return user,token
    from rest_framework.exceptions import AuthenticationFailed
from rest_framework_jwt.settings import api_settings
import jwt
# from rest_framework_jwt.utils import jwt_decode_handler
jwt_decode_handler = api_settings.JWT_DECODE_HANDLER
jwt_get_username_from_payload = api_settings.JWT_PAYLOAD_GET_USERNAME_HANDLER
from rest_framework_jwt.authentication import BaseJSONWebTokenAuthentication
from django.contrib.auth.models import User
# BaseJSONWebTokenAuthentication
class JWTAuthentication(BaseJSONWebTokenAuthentication):
    # def authenticate_credentials(self, payload):
    #     username = jwt_get_username_from_payload(payload)
    #     if not username:
    #         raise AuthenticationFailed()
    #     try:
    #         user = User.objects.get_by_natural_key(username)
    #     except User.DoesNotExist:
    #         msg = 'Invalid signature.'
    #         raise AuthenticationFailed(msg)
    #
    #     if not user.is_active:
    #         msg ='User account is disabled.'
    #         raise AuthenticationFailed(msg)
    #     return user
    def authenticate(self, request):
        print(request.META)
        # token=request.query_params.get('HTTP_AUTHORIZATION',None)
        token=request.META.get('HTTP_AUTHORIZATION',None)
        if token:
            # 校验token是不是过期了,是不是合法,
            try:
                payload = jwt_decode_handler(token)
                <
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值