麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 課堂 > 小程序 > 正文

微信小程序登錄對接Django后端實現JWT方式驗證登錄詳解

2020-03-21 15:50:32
字體:
來源:轉載
供稿:網友

先上效果圖

微信小程序,Django,后端,JWT,驗證登錄

微信小程序,Django,后端,JWT,驗證登錄

點擊授權按鈕后可以顯示部分資料和頭像,點擊修改資料可以修改部分資料。

流程

1.使用微信小程序登錄和獲取用戶信息Api接口
2.把Api獲取的用戶資料和code發送給django后端
3.通過微信接口把code換取成openid
4.后端將openid作為用戶名和密碼
5.后端通過JSON web token方式登錄,把token和用戶id傳回小程序
6.小程序將token和用戶id保存在storage中
下次請求需要驗證用戶身份的頁面時,在header中加入token這個字段

微信小程序代碼

獲取用戶信息的方法這里不展示,可以在微信小程序文檔中看到

登錄方法

login: function(event) {  wx.login({   success: res => {    console.log(res)    //請求后端換取openid的接口    http.request({     url: '/get-openid/',     method: 'POST',     data: {     //將code傳到后端      jscode: res.code     },     success: res => {      //獲取到openid作為賬號密碼      console.log(res)      console.log(app.globalData.userInfo)      http.request({       url: '/wx-login/',       method: 'POST',       data: {        openid: res.openid,        session_key: res.session_key,        nickname: app.globalData.userInfo.nickName,        avatar_url: app.globalData.userInfo.avatarUrl,        gender: app.globalData.userInfo.gender       },       //登錄成功后返回token保存在storage中       success: res => {        console.log(res)        //token存入storage        wx.setStorageSync('jwt_token', res.token)        wx.setStorageSync('user_id', res.user_id)        this.reFreshUserProfile()        //登錄狀態置為true        this.setData({         isLogin: true,         hasUserInfo: true        })        app.globalData.isLogin = true       }      })     }    })   }  }) }

注銷方法

 logout: function(res) {  this.setData({   isLogin:false,   hasUserInfo:false  })  app.globalData.isLogin = false  wx.removeStorageSync('jwt_token')  wx.removeStorageSync('user_id') },

Django后端的實現

首先安裝djangorestframework-jwt

這里不使用他默認的登錄接口,如下所示

微信小程序,Django,后端,JWT,驗證登錄

它提供了手動簽發token和解密token的功能,因此最好自己實現

手動簽發token

 jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER  jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER  payload = jwt_payload_handler(user)  token = jwt_encode_handler(payload)

手動解密token

  jwt_decode_handler = api_settings.JWT_DECODE_HANDLER  user_dict = jwt_decode_handler(token)  user_id = user_dict['user_id']

后端換取openid

class OpenId:  def __init__(self, jscode):    self.url = 'https://api.weixin.qq.com/sns/jscode2session'    self.app_id = env.str('APPID')    self.app_secret = env.str('APPSECRET')    self.jscode = jscode  def get_openid(self):    url = self.url + "?appid=" + self.app_id + "&secret=" + self.app_secret + "&js_code=" + self.jscode + "&grant_type=authorization_code"    res = requests.get(url)    try:      openid = res.json()['openid']      session_key = res.json()['session_key']    except KeyError:      return 'fail'    else:      return openid, session_key

后端返回openid接口實現

這里只使用簡單的FBV視圖

注:前端傳來的值無法從request.POST中接收到,只能使用如下方法

@require_http_methods(['POST'])@csrf_exemptdef GetOpenIdView(request):  data = json.loads(request.body)  jscode = data['jscode']  openid, session_key = OpenId(jscode).get_openid()  return JsonResponse({    'openid': openid,    'session_key': session_key  })

后端登錄接口實現

如果不存在用戶則自動創建
為了簡單,用戶名和密碼都是openid

@require_http_methods(['POST'])@csrf_exemptdef login_or_create_account(request):  data = json.loads(request.body)  print(data)  openid = data['openid']  nickname = data['nickname']  avatar_url = data['avatar_url']  gender = data['gender']  try:    user = User.objects.get(username=openid)  except User.DoesNotExist:    user = None  if user:    user = User.objects.get(username=openid)  else:    user = User.objects.create(      username=openid,      password=openid,      nickname=nickname,      avatar_url=avatar_url,      gender=gender    )  jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER  jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER  payload = jwt_payload_handler(user)  token = jwt_encode_handler(payload)  res = {    'status': 'success',    'nickname': user.nickname,    'user_id': user.id,    'token': token  }  return JsonResponse(res)

以上就是簡單的微信小程序登錄對接Django的思路,很多地方不嚴謹,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧日一级片 | chinese 军人 gay xx 呻吟 | 女教师~淫辱の动漫在线 | 欧美成人午夜一区二区三区 | 精品中文字幕久久久久四十五十骆 | 日本在线精品视频 | 亚洲成人免费影视 | 中文字幕精品一二三四五六七八 | 国产午夜精品久久久久婷 | 成人免费午夜视频 | 毛片在线视频观看 | 成人 日韩 | 久久久久国产成人免费精品免费 | 久久精品视频免费 | 精品国产一区三区 | 黄色片网站免费在线观看 | 国产成人网 | 久久精品国产99久久6动漫亮点 | lutube成人福利在线观看污 | 国产精品久久久久久久久久10秀 | 久草视频手机在线观看 | 一级黄色大片在线观看 | 精品亚洲视频在线 | 精品久久久久久久久亚洲 | 国产午夜亚洲精品午夜鲁丝片 | 欧美一级aa免费毛片 | 精品二区在线观看 | 黄www片| 亚洲一区二区三区在线看 | 黄色aaa视频 | 免费嗨片首页中文字幕 | 国产xxxxx在线观看 | 国产亚洲欧美在线视频 | 国产一区视频在线观看免费 | 成人一级黄色 | 毛片大全 | 色97色 | 日本aaa一级片 | 欧美精品一区二区久久 | 色淫影院| 久久久久久久久免费 |