理解session及微信小程序使用session

session介紹

由於Http是無狀態的協議,所以服務端需要記錄用戶的狀態時,就需要某種機制來識別具體的用戶,實現這個機制的方式就是session。

典型的場景比如購物車,當你點擊下單按鈕時,由於HTTP協議無狀態,所以並不知道是哪個用戶操作的,所以服務端要爲特定的用戶創建了特定的Session,用於標識這個用戶,並且跟蹤用戶,這樣才知道購物車裏面有幾本書。這個Session是保存在服務端的,有一個唯一標識。

那麼服務器端是如何識別特定的客戶的?

每次HTTP請求的時候,客戶端都會發送相應的Cookie信息到服務端。實際上大多數的應用都是用 Cookie 來實現Session跟蹤的,第一次創建Session的時候,服務端會在HTTP協議中告訴客戶端,需要在 Cookie 裏面記錄一個Session ID,以後每次請求把這個會話ID發送到服務器,我就知道你是誰了。

下次請求時會帶上sessionId:

實現Session跟蹤需要用到Cookie,如果客戶端的瀏覽器禁用了 Cookie 怎麼辦?


一般這種情況下,會使用一種叫做URL重寫的技術來進行會話跟蹤,即每次HTTP交互,URL後面都會被附加上一個諸如 sid=xxxxx 這樣的參數,服務端據此來識別用戶。

實現方式

服務器創建session出來後,會把session的id號,以cookie的形式回寫給客戶機,這樣,只要客戶機的瀏覽器不關,再去訪問服務器時,都會帶着session的id號去,服務器發現客戶機瀏覽器帶session id過來了,就會使用內存中與之對應的session爲之服務。

在程序中第一次調用request.getSession()方法時就會創建一個新的Session,可以用isNew()方法來判斷Session是不是新創建的。

session對象默認30分鐘沒有使用,則服務器會自動銷燬session。

當需要在程序中手動設置Session失效時,可以手工調用session.invalidate方法,摧毀session。

HttpSession session = request.getSession();
//手工調用session.invalidate方法,摧毀session
session.invalidate();

微信小程序使用session時注意的問題

微信小程序不能保存Cookie,導致每次wx.request到服務端都會創建一個新的會話(傳過去的sessionid會變化),小程序端就不能保持登錄狀態了。

一個比較簡單的辦法就是把服務端response的Set-Cookie中的值保存到Storage中。

登錄成功後,添加Cookie:

wx.setStorageSync("cookieKey", res.header["Set-Cookie"]);

然後調用接口時,在header中加入:

'Cookie': wx.getStorageSync('cookieKey')

接口調用由之前的:

wx.request({
  url: 'test.php',
  data: {
    x: '',
    y: ''
  },
  header: {
    'content-type': 'application/json' 
  },
  success (res) {
    console.log(res.data)
  }
})

變爲:

wx.request({
  url: 'test.php', 
  data: {
    x: '',
    y: ''
  },
  header: {
    'content-type': 'application/json' ,
    'Cookie': wx.getStorageSync('cookieKey')
  },
  success (res) {
    console.log(res.data)
  }
})

歡迎訪問我的個人博客:易水寒的博客

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章