广告
返回顶部
首页 > 资讯 > 精选 >Django中如何实现JWT身份验证
  • 148
分享到

Django中如何实现JWT身份验证

2023-06-14 23:06:23 148人浏览 八月长安
摘要

这篇文章主要介绍Django中如何实现Jwt身份验证,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.认证与授权验证:身份验证是验证个人或设备标识的过程。身份验证过程之一是登录过程。注册网站后,您的信息(ID,密码,

这篇文章主要介绍Django中如何实现Jwt身份验证,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

1.认证与授权

验证:身份验证是验证个人或设备标识的过程。身份验证过程之一是登录过程。注册网站后,您的信息(ID,密码,名称,电子邮件等)将存储在其数据库中。之后,您无需创建帐户即可提供信息。相反,您只需要提供用户名和密码来验证您的身份,网站就会自动知道您正在访问。

授权:授权是用于确定用户特权或访问级别的安全机制。在许多社区网站上,只有上传帖子和管理员的人才能删除它。当其他人尝试删除帖子时,网站应该抛出错误(但是在许多情况下,他们甚至看不到删除按钮)。因此,对于每个请求,用户都需要证明自己具有权限。

2.什么是JWT

JSON WEB令牌(JWT)是一种开放标准(RFC 7519),它定义了一种紧凑且自包含的方式,用于在各方之间安全地将信息作为jsON对象进行传输。您可以使用JWT对请求进行身份验证和授权。

JWT由三个串联的Base64url编码的字符串(标头,有效负载和签名)组成,并用点号(,)分隔。标头包含有关令牌和加密算法类型的元数据。签名用于验证令牌的可信度。有效负载包含用于身份验证和授权的所有必要数据。

3.存储JWT

当用户登录时,服务器将创建JWT并将其发送到客户端。然后,客户端将其存储到会话存储或本地存储。每次客户端向服务器端发送需要身份验证或授权的请求时,都会在授权标头上发送JWT。易受XSS(跨站点脚本)攻击:会话和本地存储可通过javascript访问。恶意第三方可以将其JS注入网站,从而可以向api发出请求。

服务器将JWT存储在Cookie中,并使用存储在Cookie中的JWT验证用户。Cookies容易受到CSRF的攻击,因为它们随每个请求一起发送。因此,恶意的第三方可以轻松地提出意想不到的请求。

4.DjanGo中的JWT

# settings.pySECRET_KEY = 'abcde1234',JWT_ALGORITHM = 'HS256'
# user/views.pyimport jsonfrom datetime import datetime, timdeltafrom django.conf import settingsfrom django.Http import JsonResponsefrom django.views import Viewimport bcryptimport jwtfrom .models import Userfrom token_utils import user_tokenclass UserSignInView(View):    def post(self, request):        try:            data = json.loads(request.body)            username = data['username']            pw_input = data['passWord']            user = User.objects.filter(username=username).first()            if user is None:                return JsonResponse({"message": "INVALID_USERNAME"}, status=401)            if bcrypt.checkpw(pw_input.encode('utf-8'),                              user.password.encode('utf-8')):                key = settings.SECRET_KEY                algorithm = settings.JWT_ALGORITHM                token = jwt.encode(                    {                        'iss': 'me',                        'id': user.id,                        'exp': datetime.utcnow() + timedelta(days=14)                    }, key, algorithm=algorithm).decode('utf-8')                response = JsonResponse(                    {                        'message': 'SUCCESS'                    }, status=200                )                # 当使用本地/会话存储而不是Cookie时,只需在JsonResponse中发送令牌                if data.get('remember_me') is not None:                    max_age = 14*24*60*60 # 14 days                    expires = datetime.strftime(                        datetime.utcnow() + timedelta(seconds=max_age),                        "%Y-%m-%d %H:%M:%S"                    )                    response.set_cookie(                        'token',                        token,                        max_age=max_age,                        expires=expires,                        httponly=True                    )                    return response            return JsonResponse({"message": "WRONG_PASSWORD"}, status=401)        except KeyError as e:            return JsonResponse({'message': f'KEY_ERROR: {e}'}, status=400)        except ValueError as e:            return JsonResponse({'message': f'VALUE_ERROR: {e}'}, status=400)
# token_utils.pyimport jsonfrom django.conf import settingsfrom django.http import JsonResponseimport jwtfrom user.models import Userdef user_token(func):    def wrapper(self, request, *args, **kwargs):        try:            token = request.COOKIES.get('token')            # token = request.headers.get('token')            key = settings.SECRET_KEY            algorithm = settings.JWT_ALGORITHM            if token is None:                return JsonResponse({"message": "INVALID_TOKEN"}, status=401)            decode = jwt.decode(token, key, algorithm=algorithm)            request.user = User.objects.get(id=decode['id'])        except jwt.ExpiredSignatureError:            return JsonResponse({"message": "EXPIRED_TOKEN"}, status=400)        return func(self, request, *args, **kwargs)    return wrapper

以上是“Django中如何实现JWT身份验证”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Django中如何实现JWT身份验证

本文链接: https://www.lsjlt.com/news/275893.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Django中如何实现JWT身份验证
    这篇文章主要介绍Django中如何实现JWT身份验证,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.认证与授权验证:身份验证是验证个人或设备标识的过程。身份验证过程之一是登录过程。注册网站后,您的信息(ID,密码,...
    99+
    2023-06-14
  • Django中的JWT身份验证的实现
    1.认证与授权 1.验证:身份验证是验证个人或设备标识的过程。身份验证过程之一是登录过程。注册网站后,您的信息(ID,密码,名称,电子邮件等)将存储在其数据库中。之后,您无需创建帐...
    99+
    2022-11-12
  • Java JWT如何实现跨域身份验证
    今天小编给大家分享一下Java JWT如何实现跨域身份验证的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、JWT...
    99+
    2023-06-26
  • ASP.NET项目中的JWT身份验证
    JWT (JSON Web Token) 是一种用于身份验证的开放标准,可以在客户端和服务器之间传递安全的信息。在ASP.NET项目...
    99+
    2023-09-27
    ASP.NET
  • 如何使用会话Cookie和Java实现JWT身份验证
    目录1、基于会话的身份验证那么什么是会话Cookie? 2、基于令牌的身份验证哪个更好用?3、jwt实现登录HTTP是无状态协议,用于传输数据。它启用了客户端和服务器端>...
    99+
    2022-11-11
  • Java JWT实现跨域身份验证方法详解
    目录1、JWT简介2、JWT的结构2.1 头部(header)2.2 载荷(payload)2.3 签证(signature)3、JWT的原则4、JWT的用法5、JWT的问题和趋势6...
    99+
    2022-11-12
  • Java如何实现身份证号码验证
    小编给大家分享一下Java如何实现身份证号码验证,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体如下:package xxx;import ...
    99+
    2023-05-31
    java
  • golang中gin框架接入jwt如何使用token验证身份
    本篇内容介绍了“golang中gin框架接入jwt如何使用token验证身份”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!jwtjwt的原理...
    99+
    2023-06-22
  • asp.net core3.1cookie和jwt混合认证授权实现多种身份验证方案
    目录认证授权 身份认证 授权 默认授权选择授权总结 开发了一个公司内部系统,使用asp.net core 3.1。在开发用户认证授权使用的是简单的cookie认证方式,然后开发好了要...
    99+
    2022-11-12
  • golang中gin框架接入jwt使用token验证身份
    目录jwt 流程: 1.token 工具类 2. 使用该中间件 3. controller部分代码 jwt jwt的原理和session有点相像,其目的是为了解决rest api中...
    99+
    2022-11-12
  • Golang基于JWT与Casbin身份验证授权实例详解
    目录JWTHeaderPayloadSignatureJWT的优势JWT的使用场景CasbinCasbin可以做什么Casbin不可以做什么Casbin的工作原理实践登录接口请求To...
    99+
    2022-11-11
  • 如何用sql实现18位身份证校验
    本篇文章为大家展示了如何用sql实现18位身份证校验,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。身份证校验码的计算方法1、将前面的身份证号码17位数分别乘以不同的...
    99+
    2022-10-19
  • node如何实现基于token的身份验证
    小编给大家分享一下node如何实现基于token的身份验证,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!最近研究了下基于toke...
    99+
    2022-10-19
  • go语言beego框架jwt身份认证实现示例
    目录一 引入jwt二 框架中引入jwt三 使用一 引入jwt jwt用户身份验证 go get github.com/dgrijalva/jwt-go 二 框架中引入jwt imp...
    99+
    2022-11-13
  • 怎么在Django中实现jwt认证
    本篇文章为大家展示了怎么在Django中实现jwt认证,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、 jwt 安装和配置安装虚拟环境下执行以下命令pip install dj...
    99+
    2023-06-14
  • PHP中IIS7怎么实现基本身份验证
    这篇文章主要讲解了“PHP中IIS7怎么实现基本身份验证”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP中IIS7怎么实现基本身份验证”吧!在PHP运行环境中配置IIS7实现基本身份验证...
    99+
    2023-06-17
  • JS如何实现身份证信息验证正则表达式
    小编给大家分享一下JS如何实现身份证信息验证正则表达式,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!很多时候我们都是通过一组正则...
    99+
    2022-10-19
  • Js如何实现中国公民身份证号码有效性验证
    小编给大家分享一下Js如何实现中国公民身份证号码有效性验证,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!本文将使用JavaScr...
    99+
    2022-10-19
  • Django Rest Framework实现身份认证源码详解
    目录一.Django框架二.身份认证的两种实现方式:三.身份认证源码解析流程一.Django框架 Django确实是一个很强大,用起来很爽的一个框架,在Rest Framework中...
    99+
    2022-11-11
  • VB.NET如何验证LDAP用户身份
    这篇文章主要为大家展示了“VB.NET如何验证LDAP用户身份”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“VB.NET如何验证LDAP用户身份”这篇文章吧。首先,我要讲的LDAP不是微软的Ac...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作