微信小程序之保持登錄狀態即session不改變


在微信小程序開發中,由wx.request()發起的每次請求對於服務端來說都是不同的一次會話,微信小程序不會把session信息帶回服務端,即對應服務端不同的session,由於項目中使用session保存用戶信息所以導致后續請求相當於未登錄的情況。

  注意,這里的session不是小程序維護的那個通過wx.login()方法維護的session,而是我們自己的服務端的session。

  由於正常情況下,客戶端向服務端發起請求時,session信息是存放在cookie中以請求頭的方式帶回給服務端的,而請求頭中具體的信息就是session的id,如下圖所示

 

  標紅的就是我們需要在請求時攜帶返回給服務端的請求頭 所以我們需要的就是這個JESSIONID的值了。剛好,微信小程序也提供了對請求頭的支持。

解決辦法:1、在用戶登錄時,服務端將用戶的sessionId返回。

     2、小程序保存sessionId,在之后的每次請求中在請求頭中攜帶sessionId

服務端關鍵代碼:

  獲取sessionId的方法,只要獲得request對象就可以輕松獲取到了

Sting sessionId = request.getSession().getId();

  把sessionId返回

 

...    //登錄時的業務代碼

response.getWriter.write(sessionId); //把sessionId返回給前台

 

 

 

小程序端登錄后,把sessionId存入全局變量,app.js中是個存放全局變量的好地方。

... //登錄后的邏輯處理
getApp().globalData.header.Cookie = 'JSESSIONID=' + _data.sessionId;

app.js中代碼

  globalData:{
    header:{'Cookie': ''} //這里還可以加入其它需要的請求頭,比如'x-requested-with': 'XMLHttpRequest'表示ajax提交,微信的請求時不會帶上這個的
  },

小程序端請求時帶上sessionId

復制代碼
var header = getApp().globalData.header; //獲取app.js中的請求頭
  wx.request({
    url: "localhost:8080/xx/xx",
    header: header, //請求時帶上這個請求頭
    success:function(res){
  }
}
復制代碼

建議封裝自己的請求信息,處理 一些通用的邏輯。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM