码迷,mamicode.com
首页 > 其他好文 > 详细

Django 登录接口,返回token

时间:2020-05-01 12:58:17      阅读:521      评论:0      收藏:0      [点我收藏+]

标签:try   val   统一   form   项目   mat   inview   epo   mod   

完成login之后返回token的接口,包括生成token,form校验,连接redis,view逻辑

1,在该子项目下新建utils.py ,存放生成token的类

 1 from django_redis import get_redis_connection
 2 import itsdangerous
 3 # 获取/解析token用到的模块
 4 from django.conf import settings
 5 # 把settings中的一串字符串作为 secretkey
 6 from .const import token_expires
 7 class Token:
 8     # 获取/解析token的类
 9     tjss = itsdangerous.TimedJSONWebSignatureSerializer(settings.SECRET_KEY, expires_in=token_expires)
10     # 把settings中的一串字符串作为 secretkey
11     # 设置一个失效时间
12     @classmethod
13     def create_token(cls,data):
14         token=cls.tjss.dumps(data).decode()
15         # data是根据什么获取的token,比如根据用户的用户名和密码
16         return token
17     @classmethod
18     def check_token(cls,token):
19         try:
20             data=cls.tjss.loads(token)
21             # 解析传过来的token,比如,解析成用户的用户名和密码
22         except:
23             # 如果解析失败的话。程序会报错。所以这里加了异常处理,如果解析失败,返回false即可
24             return False
25         return data

2,form校验

 1 class LoginForm(forms.Form,FormatFormError):
 2     # login form
 3     # 校验,1,传入的参数username和password数据类型是否合法
 4     # 2,username和password在sqlite数据库中能否查到,登录的信息是否正确
 5     username=forms.CharField(max_length=50)
 6     password=forms.CharField(max_length=50)
 7     def clean(self):
 8         username=self.cleaned_data.get(username)
 9         password=self.cleaned_data.get(password)
10         # 获取传到form中的参数  字典类型
11         u=models.User.objects.filter(username=username,password=password).first()
12         # 去数据表中查找这条数据
13         if u:
14             self.cleaned_data[u]=u
15             print(self.cleaned_data)
16             # 如果查到了,表明用户信息合法,并且把这条Model信息存到cleandata中
17         else:
18             raise ValidationError(账号/密码错误!)
19             # 如果查不到,直接报异常,用户信息校验失败

3,views

 1 class LoginView(View):
 2     ‘‘‘loginview‘‘‘
 3     def get(self,request):
 4         # 现在要做的登录返回token是get请求
 5         form=LoginForm(request.GET)
 6         # 把请求参数传给form,实例化form
 7         if form.is_valid():
 8             id=form.cleaned_data.get(u).id
 9             username=form.cleaned_data.get(u).username
10             # 如果校验通过,想取到这条model的id和name拼接成字典,作为加密的原始数据
11             data={id:id,username:username}
12             token=Token.create_token(data)
13             # 生成token
14             r=get_redis_connection()
15             # 建立redis的连接
16             key=session_pre+username
17             # redis中的key统一成,session:username的格式
18             r.set(key,token,token_expires)
19             # r.set(key,token)
20             return Nbreponse(username=username,token=token)
21             # 请求成功,就返回token给用户
22         else:
23             return Nbreponse(-1,form.error_msg)

 

Django 登录接口,返回token

标签:try   val   统一   form   项目   mat   inview   epo   mod   

原文地址:https://www.cnblogs.com/beautyl/p/12812229.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!