node.js - express-session 怎么支持無 cookie 的微信小程序session
問題描述
之前我的 session 是仿照 cnodejs 的源碼處理的,使用的 express-session 、cookie 獲取信息。現在我想增加一個微信小程序的登錄接口,維護登錄狀態。小程序不能使用 cookie 微信團隊提供了一個 weapp-sesion
我想請教一下大家,我現在應該怎么更改哪?才能適合兩者
問題解答
回答1:如果熟悉http session的原理,session問題就好解決了。常見的session保持方式是,當瀏覽器向服務端發起http請求時,服務端檢查在http 頭部cookie參數里是否包含sessionid,如果有sessionid就根據sessionid去查看存儲在服務器端的session,session里保存的當前會話的一些信息。如果sessionid沒有服務端就會分配一個,寫到cookie字段里,瀏覽器下次發起其它請求的時候帶上。而在小程序里所有的請求都通過wx.request API來發起的。如果對wx.request API包裝一下,使其每次向服務端發起請求時也添加一個名稱為Cookie的http header,這樣也不用對服務端作改動。服務端分配的sessionid使用wx.setStorageSync API存儲在微信客戶端。http://www.wxapp-union.com/ar...
也就是說客戶端微信小程序里面解決了存儲sessionid的問題服務端nodejs實現的session功能和普通的session實現沒區別。在小程序里面每次請求你服務器的時候把sessionid一起發過去,在服務器你先判斷是否有你發送過去的sessionid參數,若有就繼續操作session有關操作,若沒有就分配一個sessionid和response一起發送給客戶端微信小程序,在小程序里面每次收到response的時候判斷下有沒有你設置的sessionid,要是由就存儲到本地,下次請求的時候一起發過去就是了。
平時我們瀏覽器里面的cookie也就只存儲sessionid發給服務器用來識別用戶身份而已,小程序每提供session我們當然可以用wx.setStorageSync API存儲在微信客戶端代替cookie。
相關文章:
1. bootstrp是col-md-12列的,只有col-md-10有內容,可以讓沒有內容的不占據位置嗎;2. java - 如何用圖畫的方式有效地表示多線程?3. thinkPHP5中獲取數據庫數據后默認選中下拉框的值,傳遞到后臺消失不見。有圖有代碼,希望有人幫忙4. python - Fiddler+Android模擬器抓取app,json數據被加密了,如何解析?5. 常量在外面不加引號會報錯。6. sublime text3安裝package control失敗7. python 3.4 error: Microsoft Visual C++ 10.0 is required8. 百度地圖 - Android app中準備接入地圖sdk,百度VS高德哪個好一點?9. wordpress里,這樣的目錄列表是屬于小工具還是啥?10. 我的怎么不顯示啊,話說有沒有QQ群什么的
