微信小程序python 用戶認(rèn)證

這里用到django-rest-framework-jwt這個庫 https://github.com/GetBlimp/django-rest-framework-jwt

按流程圖來

先通過wx.login()獲取code,再通過我們后臺配置的接口獲取openid和session_key

  // 登錄
  wx.login({
    success: res => {
      console.log(res)
      // 發(fā)送 res.code 到后臺換取 openId, sessionKey, unionId
         wx.request({
            url: api.GET_OPENID, //
            data: {
              js_code: res.code
            },
            success: function (res) {
              var openid = res.data.openid
              var session_key = res.data.session_key
              //獲取openid唉锌,session_key
              //后臺用戶表保存
              wx.request({
                url: api.USER,
                method: "POST",
                data: {
                  openid : openid栅炒,
                  session_key : session_kay
                },
                success: function (res) {
                  if (res.data.status == 'success') {
                    //在緩存中保存用戶id和openid備用
                    wx.setStorage({
                      key: 'userid',
                      data: res.data.userid,
                    });
                    wx.setStorage({
                      key: 'openid',
                      data: openid,
                    })
                  } else {
                    wx.showModal({
                      title: '提示',
                      showCancel: false,
                      content: '獲取openid失敗',
                    })
                  }
                }
              })
            }
          })
    }
  })

在這里的用戶表最好是在django自帶的user表上進(jìn)行字段拓展草则,不然重寫起來會很麻煩,拓展方法如下

from django.contrib.auth.models import AbstractUser

# Create your models here.
class User(AbstractUser):
    """
    用戶新增字段
    """
    name = models.CharField(max_length=30, null=True, blank=True, verbose_name="姓名")

下面是django的user默認(rèn)字段,需要保存用戶頭像庭敦,用戶省市等字段只要在原有基礎(chǔ)上新增即可


生成3rd session

先在后臺配置jwt
安裝 pip install djangorestframework-jwt
在你的settings.py碴卧,添加JSONWebTokenAuthentication到Django REST框架DEFAULT_AUTHENTICATION_CLASSES。

REST_FRAMEWORK = {
    'DEFAULT_PERMISSION_CLASSES': (
        'rest_framework.permissions.IsAuthenticated',
    ),
    'DEFAULT_AUTHENTICATION_CLASSES': (
        'rest_framework_jwt.authentication.JSONWebTokenAuthentication', # <-------
        'rest_framework.authentication.SessionAuthentication',
        'rest_framework.authentication.BasicAuthentication',
    ),
}

#JWT設(shè)置過期時間,具體配置查看文檔
JWT_AUTH = {
    'JWT_VERIFY_EXPIRATION': False
}

#在您urls.py添加以下URL路由以啟用通過POST獲取令牌包括用戶的用戶名和密碼沮协。

from rest_framework_jwt.views import obtain_jwt_token
#...

urlpatterns = [
    '',
    # ...

    url(r'^api-token-auth/', obtain_jwt_token),
]

通過POST用戶的用戶名和密碼獲取token

                wx.request({
                  url: api.api-token-auth,//url配置
                  method: 'POST',
                  data: {
                    'username': openid,          //這里我是用openid當(dāng)作用戶名
                    'password': session_key      //用session_key當(dāng)作密碼
                  },
                  success: function(jwt) {
                    //jwt格式:eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoxLCJ1c2VybmFtZSI6InhpZWhhbyIsImV4cCI6MTUzNTM3ODQ2OCwiZW1haWwiOiIzNDg2OTg1ODhAcXEuY29tIn0.8rXFK_K2q8474LxYrCuuNJT93PkZMzi1JX6fVproXrE
                    //前面是base64后面是簽名,用.隔開
                    //將jwt_token放入緩存?zhèn)溆?                    var jwt_token = jwt.data.token
                    wx.setStorageSync('jwt_token', jwt_token)
                    self.globalData.jwt_token = jwt_token
                  }
                })

后端配置時需要加上authentication_classes進(jìn)行認(rèn)證

from rest_framework.permissions import IsAuthenticated
from rest_framework_jwt.authentication import JSONWebTokenAuthentication

# 商品表
class goodsViewSet(viewsets.ModelViewSet):
    queryset = Goods.objects.all()
    serializer_class = goodsSerializers
    filter_class = GoodsFilter
    filter_backends = (DjangoFilterBackend, filters.SearchFilter)
    search_fields = ('name',)
    #認(rèn)證配置
    permission_classes = (IsAuthenticated,)
    authentication_classes = (JSONWebTokenAuthentication,)

使用方法

在請求加了認(rèn)證的view時卓嫂,如果不在head中帶入jwt_token慷暂,請求401


在header中帶入請求數(shù)據(jù)成功

    //從緩存中取出jwt_token,并按文檔用法拼接,在header中帶入Authorization
    // JWT +jwt_token
    var jwt_token = 'JWT  ' + wx.getStorageSync('jwt_token')

    wx.request({
      url: 'http://127.0.0.1:8000/mall/goods/',
      header:{
         'Authorization': jwt_token
      },
      success:function(res){
        //成功請求到商品數(shù)據(jù)
        console.log(res)
      }
    })

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市晨雳,隨后出現(xiàn)的幾起案子行瑞,更是在濱河造成了極大的恐慌,老刑警劉巖餐禁,帶你破解...
    沈念sama閱讀 221,430評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件血久,死亡現(xiàn)場離奇詭異,居然都是意外死亡坠宴,警方通過查閱死者的電腦和手機(jī)洋魂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來喜鼓,“玉大人副砍,你說我怎么就攤上這事∽” “怎么了豁翎?”我有些...
    開封第一講書人閱讀 167,834評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長隅忿。 經(jīng)常有香客問我心剥,道長,這世上最難降的妖魔是什么背桐? 我笑而不...
    開封第一講書人閱讀 59,543評論 1 296
  • 正文 為了忘掉前任优烧,我火速辦了婚禮,結(jié)果婚禮上链峭,老公的妹妹穿的比我還像新娘畦娄。我一直安慰自己,他們只是感情好弊仪,可當(dāng)我...
    茶點故事閱讀 68,547評論 6 397
  • 文/花漫 我一把揭開白布熙卡。 她就那樣靜靜地躺著,像睡著了一般励饵。 火紅的嫁衣襯著肌膚如雪驳癌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,196評論 1 308
  • 那天役听,我揣著相機(jī)與錄音颓鲜,去河邊找鬼表窘。 笑死,一個胖子當(dāng)著我的面吹牛灾杰,可吹牛的內(nèi)容都是我干的蚊丐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼艳吠,長吁一口氣:“原來是場噩夢啊……” “哼麦备!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起昭娩,我...
    開封第一講書人閱讀 39,671評論 0 276
  • 序言:老撾萬榮一對情侶失蹤凛篙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后栏渺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體呛梆,經(jīng)...
    沈念sama閱讀 46,221評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,303評論 3 340
  • 正文 我和宋清朗相戀三年磕诊,在試婚紗的時候發(fā)現(xiàn)自己被綠了填物。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,444評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡霎终,死狀恐怖滞磺,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情莱褒,我是刑警寧澤击困,帶...
    沈念sama閱讀 36,134評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站广凸,受9級特大地震影響阅茶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜谅海,卻給世界環(huán)境...
    茶點故事閱讀 41,810評論 3 333
  • 文/蒙蒙 一脸哀、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧扭吁,春花似錦企蹭、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽徒河。三九已至系馆,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間顽照,已是汗流浹背由蘑。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評論 1 272
  • 我被黑心中介騙來泰國打工闽寡, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尼酿。 一個月前我還...
    沈念sama閱讀 48,837評論 3 376
  • 正文 我出身青樓爷狈,卻偏偏與公主長得像,于是被迫代替她去往敵國和親裳擎。 傳聞我的和親對象是個殘疾皇子涎永,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,455評論 2 359

推薦閱讀更多精彩內(nèi)容