Heim > WeChat-Applet > Mini-Programmentwicklung > So implementieren Sie Anmeldung und Autorisierung für Miniprogramme

So implementieren Sie Anmeldung und Autorisierung für Miniprogramme

王林
Freigeben: 2021-03-01 09:59:41
nach vorne
3034 Leute haben es durchsucht

So implementieren Sie Anmeldung und Autorisierung für Miniprogramme

Anmeldung:

Wenn wir die Anmeldung des Miniprogramms implementieren möchten, können wir genauso gut versuchen, die Anmeldung beim Öffnen des Miniprogramms abzuschließen. Mit anderen Worten: Wir können den Anmeldecode für das Miniprogramm in der Onlaunch-Methode in app.js hinzufügen.

Wie folgt:

//微信的登录方法wx.login({      success: res => {          //登录成功后会返回一个微信端提供的 code ,用来自定义登录使用
        console.log("code",res.code);          //向自己的后台发送请求
        wx.request({          url: this.globalData.URL+'login/',          data:{            code:res.code
          },          header:{            "content-type": "application/json"
          },          method:"POST",          success:function(e){            console.log(e)              //请求成功后会返回一个自己后端生成的 token 用来做其他操作的校验,把token保存在本地
            wx.setStorageSync("token", e.data.data.token)
          }
        })        // 发送 res.code 到后台换取 openId, sessionKey, unionId
      }
    })
Nach dem Login kopieren

Backend-Code:

from rest_framework.views import APIViewfrom rest_framework.response import Responsefrom app01.wx import Wx_loginfrom django.core.cache import cachefrom app01 import modelsimport timeimport hashlibclass Login(APIView):
    def post(self,request):
        param = request.data        if param.get("code"):            #Wx_login是微信为我们提供的登录方法,这里的data已经有一个session_key和openid了
            data=Wx_login.login(param.get("code"))            if data:                # 1 session_key+时间戳等到一个key.(md5
                md5=hashlib.md5()
                md5.update(data.get("session_key").encode("utf8"))
                md5.update(str(time.time()).encode("utf8"))
                key=md5.hexdigest()                #2 session_key与openid做绑定等到val
                val=data.get("session_key")+'&'+data.get("openid")                #3key->val存到redis,
                cache.set(key,val)                #4把openid存到数据库
                user_data=models.Wxuser.objects.filter(openid=data.get("openid")).first()                if not user_data:
                    models.Wxuser.objects.create(openid=data.get("openid"))                #5把key返回给小程序
                return Response({"code": 200, "msg": "suc","data":{"token":key}})            else:                return Response({"code": 202, "msg": "code无效"})        else:            return Response({"code":201,"msg":"缺少参数"})
Nach dem Login kopieren

Wx_login

import requests# appid={}&secret={}&js_code={}from app01.wx import settingsdef login(code):
    #code2Session是wx提供的url,填入你的appid和appsecret以及前端发送来的code
        url=settings.code2Session.format(settings.AppId,settings.AppSecret,code)

    reponse=requests.get(url=url)    #得到的data里面有session_key和openid。
    data=reponse.json()
    print(data)    if data.get("session_key"):        return data    else:        return False
Nach dem Login kopieren

settings

#你注册的小程序的 appid 和 appsecret,code2Session是有官方提供的。pay_mchid是商铺号,需要工商证才能办理,所以自己没法搞。
AppId="wx69a0dca5c6b02a43"AppSecret="9d0f80642f4861b53df04a2f7bd65a59"code2Session="https://api.weixin.qq.com/sns/jscode2session?appid={}&secret={}&js_code={}&grant_type=authorization_code"pay_mchid ='1415981402'pay_apikey = 'xi34nu5jn7x2uujd8u4jiijd2u5d6j8e'
Nach dem Login kopieren

Die Anmeldung ist abgeschlossen

Autorisierung

html ist nur eine Schaltfläche plus ein Klickereignis, ich werde es nicht aufschreiben, Hängt hauptsächlich vom Klick ab. Was hat das Ereignis bewirkt? Wenn Sie die Informationen im Front-End erhalten möchten, müssen Sie eine Genehmigung einholen.

Es ist zu beachten, dass diese Methode falsch ist

Sie muss so geschrieben werden, dass beim Empfang der Anfrage einige wichtige Dinge an das Klickereignis übergeben werden.

<button bind:tap="info">用户信息</button>
Nach dem Login kopieren

js

<button open-type="getUserInfo" bindgetuserinfo="info1">获取用户信</button>
Nach dem Login kopieren

Verwandte Empfehlungen:

Mini-Tutorial zur Programmentwicklung

Das obige ist der detaillierte Inhalt vonSo implementieren Sie Anmeldung und Autorisierung für Miniprogramme. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:cnblogs.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage