JWT token 相关配置 (全局配置 身份认证 重写Authenticate方法)

一. jwt 全局配置

1.settings配置

REST_FRAMEWORK = {
    # 身份认证
    'DEFAULT_AUTHENTICATION_CLASSES': (
    'rest_framework_jwt.authentication.JSONWebTokenAuthentication',),
}

import datetime
JWT_AUTH = {
    # jwt过期时间差值  3天过期
    'JWT_EXPIRATION_DELTA': datetime.timedelta(days=3),
    # 自定义返回的json数据   ****下一步加入
    'JWT_RESPONSE_PAYLOAD_HANDLER': 'users.utils.jwt_response_payload_handler',
}

二. 配置jwt过期时间 自定义返回的json数据

1.utils.py函数编写,返回指定格式的json数据

users.utils.jwt_response_payload_handler: 创建在users app下的utils.py的jwt_response_payload_handler函数
注意: jwt_response_payload_handler函数需要写

 在 users app下创建utils.py 然后编写

# 返回指定格式的json数据 token
def jwt_response_payload_handler(*args, **kwargs):
    print('args:', args)
    print('kwargs:', kwargs)
    token, user, request = args
    return {
        'code': 200,
        'username': user.username,
        'user_id': user.id,
        'token': token
    }

2.settings配置

 settings 配置文件里

import datetime
JWT_AUTH = {
    # jwt过期时间差值  3天过期
    'JWT_EXPIRATION_DELTA': datetime.timedelta(days=3),
    # 自定义返回的json数据
    'JWT_RESPONSE_PAYLOAD_HANDLER': 'users.utils.jwt_response_payload_handler',
}

三. 配置django的认证后端 目的是只让管理员登录 自定义一个认证类 重写Authenticate方法

users.utils.MyAuthentication: 创建在users app下的utils.py的MyAuthentication类
注意: MyAuthentication 类需要写 继承认证父类ModelBackend

1.utils.py类编写 重写Authenticate方法

在 users app下创建utils.py 然后编写

# 只让管理员登录 
class MyAuthentication(ModelBackend):
    def authenticate(self, request, username=None, password=None, **kwargs):
        # 查询用户对象  可通过密码和手机号登录
        user = User.objects.filter(Q(username=username) | Q(phone=username)).first()
        # 判断 用户,密码, 是否是管理员
        if user and check_password(password, user.password) and user.is_staff:
            return user    # 验证通过返回对象 否则返回None
        else:
            return None

2.settings配置

 settings 配置文件里

AUTHENTICATION_BACKENDS = [
    'users.utils.MyAuthentication',  # 自定义认证
]

四. 路由配置

不继承视图类,而是obtain_jwt_token
接口根据具体需要修改

urlpatterns = [
    
    # 管理员登录验证
    path('login/', obtain_jwt_token),
   
]

五. 模型类

1.models.py里定义用户类

# 用户类
class User(AbstractUser):
    phone = models.CharField('手机号', max_length=11, null=True, unique=True, blank=True)
    last_login = models.DateTimeField('上次登录',  null=True, blank=True)
    def __str__(self):
        return self.username

    class Meta:
        db_table = "user_tb"
        verbose_name_plural = '用户表'

2.settings配置

# 认证的用户模型类
AUTH_USER_MODEL = 'users.User'

3 添加测试数据

通过 python manage.py shell 密文添加
在这里插入图片描述


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 JWT(JSON Web Token)进行身份验证和授权的应用程序中,可以通过配置拦截器来拦截请求并验证 JWT Token 的有效性。下面是一个示例的 JWT Token 拦截器配置: 1. 首先,创建一个拦截器类,例如 `JwtTokenInterceptor`,实现 `HandlerInterceptor` 接口。 ```java import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class JwtTokenInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在这里编写拦截器的逻辑 // 例如,获取请求头中的 Authorization 字段,解析 JWT Token,并验证其有效性 // 如果验证失败,可以返回适当的错误响应或者重定向到登录页面 // 如果验证成功,可以继续处理请求 return true; } } ``` 2. 在 Spring Boot 的配置类中注册拦截器。 ```java import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class WebConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { // 注册 JwtTokenInterceptor,并指定需要拦截的路径 registry.addInterceptor(new JwtTokenInterceptor()) .addPathPatterns("/api/**"); // 拦截以 "/api" 开头的请求 } } ``` 在上述示例中,`JwtTokenInterceptor` 类实现了 `HandlerInterceptor` 接口,并重写了其中的 `preHandle` 方法。在该方法中,你可以编写验证 JWT Token 的逻辑,例如解析 Token,并判断其是否有效。如果 Token 有效,返回 `true`,继续处理请求;如果无效,可以返回适当的错误响应或者重定向到登录页面。 然后,在 Spring Boot 的配置类中,通过 `addInterceptors` 方法注册 `JwtTokenInterceptor` 拦截器,并使用 `addPathPatterns` 指定需要拦截的请求路径。 请注意,上述示例仅为演示拦截器的基本配置,实际使用过程中可能需要根据你的具体需求进行相应的修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值