我是大猩猩會話(和一般餅干)的初學者,我一直在嘗試它。在文檔中,他們有以下代碼:session, err := store.Get(r, "session-name")if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return}// Set some session values.session.Values["foo"] = "bar"session.Values[42] = 43// Save it before we write to the response/return from the handler.err = session.Save(r, w)if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return}根據我對會話的理解,您需要一個成功登錄的用戶才能接收會話“令牌”,然后將其存儲到商店中。這條線似乎store.Get(r, "session-name")就是這樣做的,實際上“會話名稱”將是成功驗證的用戶 ID。這里的目標是能夠檢索和比較未來請求的會話令牌。(對嗎?)我不明白的是那些被保存的價值是什么:// Set some session values.session.Values["foo"] = "bar"session.Values[42] = 43我們用它們做什么?是否存儲在 cookie 發回給我們時將被檢索的額外數據?是否留在后端存儲?或以與 JWT 對有效負載中的額外數據進行編碼的相同方式編碼并添加到 cookie(如用戶的角色等)在我看來,只有第一步是必要的,但我不確定其余的,特別是因為store.Get()沒有參數應該生成一個會話,如文檔示例中所述“//獲取一個會話。Get() 總是返回一個會話,即使是空的?!?id 所以我可以將它保存在我的數據庫/redis/內存中,而根本不使用其余部分。我覺得我錯過了什么。
1 回答

侃侃無極
TA貢獻2051條經驗 獲得超10個贊
store.Get 方法使用 request 對象獲取 sessionid,然后從 store 中獲取 session 數據,然后創建 session 對象。
session.Values 使用映射來保存會話數據。讀寫 session.Values 是為了操作會話數據。最后調用 session.Save 方法將新序列化中的數據保存到存儲中。
- 1 回答
- 0 關注
- 123 瀏覽
添加回答
舉報
0/150
提交
取消