免费国产欧美国日产_少妇AV一区二区三区无码_蜜桃精品av无码喷奶水小说_jk18禁网站视频_精产国品一二三级产品区别_被夫の上司に犯波多野结衣_78m成人手机免费看_最爽最刺激18禁视频_偷偷色噜狠狠狠狠的777米奇

易優(yōu)GEO 重磅上線 ~ 一站式GEO優(yōu)化工具,讓豆包、文心一言、DeepSeek 在回答中主動推薦你的品牌,搶占AI流量入口!  點(diǎn)擊查看

小程序模板網(wǎng)

java實(shí)現(xiàn)微信小程序登錄態(tài)維護(hù)

發(fā)布時(shí)間:2018-04-25 09:19 所屬欄目:小程序開發(fā)教程

相信不少喜歡開發(fā)的朋友都已經(jīng)知道微信小程序是個(gè)什么物種了,樓主也是從小程序內(nèi)測期間就開始關(guān)注,并且也寫過幾個(gè)已經(jīng)上線的微信小程序。但是基本上都是寫的純前端,最近樓主從后端到前端寫一個(gè)完整的小程序項(xiàng)目,中間碰到了一些問題,樓主會找一些個(gè)人覺得有學(xué)習(xí)價(jià)值的點(diǎn)不定時(shí)的拿出來跟大家分享,希望對你有一些幫助。

    本次就從最基本的微信小程序登錄態(tài)維護(hù)開始吧。小程序官方api文檔里面有對登錄態(tài)的一個(gè)完整的解釋,并且有相關(guān)的代碼。想看詳情,可以出門右轉(zhuǎn):https://mp.weixin.qq.com/debug/wxadoc/dev/api/api-login.html#wxloginobject我第一次看的時(shí)候沒怎么看懂,并且代碼沒有提供java版本的,這讓一個(gè)java程序員情何以堪,所以在努力研究了以后決定要做一個(gè)java版本的簡單的demo放出來。

    作為服務(wù)端,如果想獲得到使用微信小程序的會員信息,就需要小程序作為客戶端把會員的基本信息傳過來。類似于手機(jī)號,openId可以作為當(dāng)前小程序中用戶的唯一性標(biāo)志。然而如果把會員的openId信息明文直接在服務(wù)端與小程序端來回傳輸?shù)脑?,會有安全性的問題。萬一被別人得到這個(gè)openId,就相當(dāng)于得到會員的手機(jī)號一樣,就可以做一些其他操作了,顯然是不安全的。

    為了解決這一問題微信采用了相對安全的方式。

 

				
  1. //app.js
  2. App({
  3. onLaunch: function() {
  4. wx.login({
  5. success: function(res) {
  6. if (res.code) {
  7. //發(fā)起網(wǎng)絡(luò)請求
  8. wx.request({
  9. url: 'https://test.com/onLogin',
  10. data: {
  11. code: res.code
  12. }
  13. })
  14. } else {
  15. console.log('獲取用戶登錄態(tài)失?。?#39; + res.errMsg)
  16. }
  17. }
  18. });
  19. }
  20. })

微信小程序端會調(diào)用wx.login的api,然后會得到一個(gè)code,這個(gè)code對外人來講是沒有任何意義的,可以放心的傳給服務(wù)端。服務(wù)端得到code以后,加上你申請小程序時(shí)的appId, app secret,去調(diào)微信的接口

https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code  就可以得到以下參數(shù):

openid 用戶唯一標(biāo)識  session_key 會話密鑰  unionid 本字段在滿足一定條件的情況下才返回  其中openid 就是會員的唯一性標(biāo)記,此時(shí)服務(wù)端可以保存下來。  session_key 以后解密 unionId(整個(gè)開放平臺會員的唯一性標(biāo)識)時(shí)有用。

    服務(wù)端得到openid以后,為了后邊的交互,要保存下來。一般來講有兩種方式:一種是直接入數(shù)據(jù)庫,一種是采用效率高一點(diǎn)的緩存。樓主采用的是后者,方式是redis。

    按照微信的建議此時(shí)需要生成一個(gè)不重復(fù)值作為openId的唯一性標(biāo)識。這里采用的是java的uuid。然后把這個(gè)uuid值作為key,把openid以及后面會用到的session_key作為value,存進(jìn)redis。并且把uuid值返回給小程序。這樣小程序就可以直接拿uuid值跟服務(wù)端交互。

    也許會有人問,如果有人得到uuid值其實(shí)跟得到openid沒什么區(qū)別啊,都相當(dāng)于是會員的唯一性標(biāo)志。

    所以這里要對這個(gè)uuid值進(jìn)行一個(gè)處理。首先存入redis時(shí)要有時(shí)效性。session_key在微信服務(wù)器有效期是30天,建議服務(wù)端緩存session_key不超過30天。當(dāng)小程序傳過來的uuid值過期時(shí),認(rèn)為這是過期的uuid,則重新走wx.login步驟。

    為了方便redis中不僅會寸uuid與openid的對應(yīng)關(guān)系。還會再存一條openid對應(yīng)uuid的記錄,目的是為了下一次重新wx.login步驟時(shí)根據(jù)openid找到之前老的uuid,如果存在的話就刪掉,然后查詢一條新的uuid值,并且把openid對應(yīng)的這條記錄也更新掉。這樣redis服務(wù)器中就不會有多余的臟數(shù)據(jù),減輕服務(wù)器的負(fù)擔(dān)。

    以上就是我理解的整個(gè)登錄態(tài)的過程,當(dāng)然還有wx.checkSession這些沒有講到,其實(shí)就是發(fā)現(xiàn)session_key失效是再重新走一遍上述的流程就可以了。所以沒有仔細(xì)說。不知道我有沒有講清楚。我會把整個(gè)流程的關(guān)鍵代碼貼出來,供大家參考。

 

				
  1. @ActionKey("/loginByWeixin")
  2. public void loginByWeixin() throws Exception {
  3. logger.info("Start getSessionKey");
  4. String json = HttpKit.readData(getRequest());
  5. JSONObject reqJson = JSON.parseObject(json);
  6. String jsCode = reqJson.getString("code");
  7. if (jsCode == null || "".equals(jsCode)) {
  8. logger.info("缺少必要參數(shù)");
  9. renderJson(new OutRoot().setCode("100").setMsg(SYS.PARAMETER_FAIL));
  10. } else {
  11. List<Record> record = appInfoService.selectAppInfo();
  12. String appId = record.get(0).get("app_id");
  13. String appSecret = record.get(0).getStr("app_secret");
  14. if (appId == null || "".equals(appId) || appSecret == null || "".equals(appSecret)) {
  15. logger.info("缺少必要參數(shù)");
  16. renderJson(new OutRoot().setCode("100").setMsg(SYS.PARAMETER_FAIL));
  17. } else {
  18. String url = "https://api.weixin.qq.com/sns/jscode2session";
  19. String httpUrl = url + "?appid=" + appId + "&secret=" + appSecret + "&js_code=" + jsCode
  20. + "&grant_type=authorization_code";
  21. String ret =


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://www.szcjxy.com/wxmini/doc/course/23969.html 復(fù)制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢: 點(diǎn)擊咨詢
在線客服