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

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

微信小程序登錄數據解密及狀態維持實例詳解

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

本文實例講述了微信小程序登錄數據解密及狀態維持。分享給大家供大家參考,具體如下:

學習過小程序的朋友應該知道,在小程序中是不支持cookie的,借助小程序中的緩存我們也可以存儲一些信息,但是對于一些比較重要的信息,我們需要通過登錄狀態維持來保存,同時,為了安全起見,用戶的敏感信息,也是需要加密在網絡上傳輸的。

前臺,service。封裝了http請求,同時封裝了getSession(通過code獲取服務器生成的session)、getUserInfo(獲取用戶信息)、getDecryptionData(解密數據)

//service.js//封裝了http服務,getUserInfo,提供回調函數var recourse = { doMain: "http://www.domain.com/"}module.exports = { //Http Get requestGet: function (url, data, cb) {  wx.request({   url: recourse.doMain + url,   data: data,   method: 'GET',   header: {},   success: function (res) {    cb(res, true)   },   fail: function () {    cb(data, false)   }  }) }, //Http POST requestPost: function (url, data, cb) {  wx.request({   url: recourse.doMain + url,   data: data,   method: 'POST',   header: {},   success: function (res) {    cb(res, true)   },   fail: function () {    cb(data, false)   }  }) }, //獲取第三方sessionId getSession: function (code, cb) {  wx.request({   url: recourse.doMain + 'SmallRoutine/PostCode',   data: { code: code },   method: 'POST',   success: function (res) {    cb(res, true)   },   fail: function (res) {    cb(res, false)   }  }) }, //獲取用戶信息 getUserInfo: function (cb) {  wx.getUserInfo({   success: function (res) {    cb(res, true)   },   fail: function (res) {    cb(res, false)   }  }) }, //獲取解密數據 getDecryptionData: function (cb) {  wx.request({   url: recourse.doMain+'SmallRoutine/Decryption',   data: {    encryptedData: wx.getStorageSync('encryptedData'),    iv: wx.getStorageSync('iv'),    session: wx.getStorageSync('thirdSessionId'),   },   method: 'POST',   success: function (res) {    cb(res, true)   },   fail: function (res) {    cb(res, false)   }  }) }}

后臺,根據code獲取session,客戶端用來保持登錄狀態

[HttpPost]public ActionResult PostCode(string code){  try  {    if(!string.IsNullOrEmpty(code))    {      HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(string.Format("https://api.weixin.qq.com/sns/jscode2session?appid={0}&secret={1}&js_code={2}&grant_type=authorization_code",appId,appSecret,code));      request.Method = "GET";      HttpWebResponse response = (HttpWebResponse)request.GetResponse();      StreamReader sr = new StreamReader(response.GetResponseStream());      string content = sr.ReadToEnd();      if(response.StatusCode == HttpStatusCode.OK)      {        var successModel = Newtonsoft.Json.JsonConvert.DeserializeObject<ValidateCodeSuccess>(content);        if(null != successModel.session_key)        {          //session_key是微信服務器生成的針對用戶數據加密簽名的密鑰,不應該傳輸到客戶端          var session_key = successModel.session_key;          //3re_session用于服務器和小程序之間做登錄狀態校驗          var thirdSession = Guid.NewGuid().ToString().Replace("-","");          var now = DateTime.Now;          //存到數據庫或者redis緩存,這里一小時過期          Service.AddLogin(new Domain.Login()          {            Code = code,            Createime = now,            OpenId = successModel.openid,            OverdueTime = now.AddMinutes(60),            SessionKey = successModel.session_key,            SessionRd = thirdSession          });          return Json(new { success = true,session = thirdSession,openId = successModel.openid });        }        else        {          var errModel = Newtonsoft.Json.JsonConvert.DeserializeObject<ValidateCodeFail>(content);          return Json(new { success = false,msg = errModel.errcode + ":" + errModel.errmsg });        }      }      else      {        var errModel = Newtonsoft.Json.JsonConvert.DeserializeObject<ValidateCodeFail>(content);        return Json(new { success = false,msg = errModel.errcode + ":" + errModel.errmsg });      }    }    else    {      return Json(new { success = false,msg = "code不能為null" });    }  }  catch(Exception e)  {    return Json(new { success = false });  }}

解密敏感信息

[HttpPost]public ActionResult Decryption(string encryptedData,string iv,string session){  try  {    var sessionKey = Service.GetSessionKey(session);    if(!string.IsNullOrEmpty(sessionKey))    {      var str = AESDecrypt(encryptedData,sessionKey,iv);      var data = Newtonsoft.Json.JsonConvert.DeserializeObject<EncryptedData>(str);      if(null != data)      {        //服務器可以更新用戶信息        return Json(new { success = true,data = data });      }    }  }  catch(Exception e)  {    Service.AddLog("翻譯錯誤:"+e.ToString());  }  return Json(new { success = false });}

AES解密

public static string AESDecrypt(string encryptedData,string key,string iv){  if(string.IsNullOrEmpty(encryptedData)) return "";  byte[] encryptedData2 = Convert.FromBase64String(encryptedData);  System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged  {    Key = Convert.FromBase64String(key),    IV = Convert.FromBase64String(iv),    Mode = System.Security.Cryptography.CipherMode.CBC,    Padding = System.Security.Cryptography.PaddingMode.PKCS7  };  System.Security.Cryptography.ICryptoTransform ctf = rm.CreateDecryptor();  Byte[] resultArray = ctf.TransformFinalBlock(encryptedData2,0,encryptedData2.Length);  return Encoding.UTF8.GetString(resultArray);}

判斷用戶是否掉線

[HttpPost]public ActionResult PostSession(string session){  if(!string.IsNullOrEmpty(session))  {    var loginInfo = Service.GetLoginInfo(session);    if(null != loginInfo)    {      return Json(new { success = true,openId = loginInfo.OpenId });    }    else    {      return Json(new { success = false });    }  }  return Json(new { success = false });}

前臺index.js

//index.jsvar app = getApp()Page({ data: {  userInfo: {}, }, onLoad: function () {  var that = this  app.getUserInfo(function (userInfo) {   //更新數據   that.setData({    userInfo: userInfo   })  }) }})

前臺app.js

var service = require('./service/service.js')var appConfig = {  getUserInfo: function (cb) {    var that = this    if (that.globalData.userInfo) {      //從緩存中用戶信息    } else {      //wx api 登錄      wx.login({        success: function (res) {          console.log('登錄成功 code 為:' + res.code);          if (res.code) {            service.getSession(res.code, function (res, success) {              if (success) {                console.log('通過 code 獲取第三方服務器 session 成功, session 為:' + res.data.session);                //緩存起來                wx.setStorageSync('thirdSessionId', res.data.session);                //wx api 獲取用戶信息                service.getUserInfo(function (res, success) {                  if (success) {                    console.log('獲取用戶信息成功, 加密數據為:' + res.encryptedData);                    console.log('獲取用戶信息成功, 加密向量為:' + res.iv);                    //緩存敏感的用戶信息,解密向量                    wx.setStorageSync('encryptedData', res.encryptedData);                    wx.setStorageSync('iv', res.iv);                    that.globalData.userInfo = res.userInfo;                    //解密數據                    service.getDecryptionData(function (res, success) {                      if (success) {                        console.log("解密數據成功");                        console.log(res.data.data);                      } else {                        console.log('解密數據失敗');                      }                    })                  } else {                    console.log('獲取用戶信息失敗')                  }                });              } else {                console.log('通過 code 獲取第三方服務器 session 失敗');              }            });          } else {            console.log('登錄失敗:');          }        }      })    }  },  globalData: {    userInfo: null  }}App(appConfig)

運行輸出

微信小程序,數據解密,狀態維持

希望本文所述對大家微信小程序開發有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人羞羞在线观看网站 | 在线日韩亚洲 | 猫咪av在线| 中文字幕在线观看91 | 日韩精品中文字幕在线观看 | 成人午夜在线免费观看 | 国产高潮国产高潮久久久91 | 法国极品成人h版 | 成人在线视频免费观看 | 欧美一区二区三区中文字幕 | chinese xxxx hd pron8 tube | 亚洲一区二区三区视频免费 | 污片视频在线观看 | 国产羞羞视频在线观看免费应用 | 中国av免费在线观看 | 在线高清中文字幕 | 黄色大片在线观看 | 99视频有精品视频高清 | 男女生羞羞视频网站在线观看 | 成人羞羞国产免费游戏 | 国产精品一区二区三区在线看 | 多人乱大交xxxxx变态 | 欧美一级高清免费 | 免费观看一级淫片 | 香蕉视频网站在线观看 | 国产精品视频在线观看免费 | 99视频网 | 欧美一级做一级爱a做片性 91在线视频观看 | 小情侣嗯啊哦视频www | 日本在线观看高清完整版 | 欧美亚洲免费 | 特级黄一级播放 | 黄色一级片在线免费观看 | 国产亚洲精品久久久久5区 综合激情网 | 精品一区二区三区日本 | 国产精品午夜未成人免费观看 | 91 免费看片 | 欧美精品在线视频观看 | 91中文字幕在线观看 | 午夜精品老牛av一区二区三区 | 午夜视 |