瀏覽器不儲存Golang後端發送的cookie
php小編草莓在這裡為大家介紹一個瀏覽器保存cookie的問題。有時候我們在使用Golang後端發送cookie時,發現瀏覽器並沒有儲存下來。這可能是由於一些原因導致的,例如瀏覽器的隱私設定或是程式碼中的一些問題。在本文中,我們將詳細探討這個問題,並提供一些解決方案來確保瀏覽器能夠正確保存Golang後端發送的cookie。讓我們開始吧!
問題內容
我知道這個問題已經被問過很多次了,但我嘗試了大部分答案,但仍然無法讓它發揮作用。
我有一個有 net/http 套件和 js 前端的 golang api。我有一個函數
func setcookie(w *http.responsewriter, email string) string { val := uuid.newstring() http.setcookie(*w, &http.cookie{ name: "gocookie", value: val, path: "/", }) return val }
該函數在用戶登入時被調用,我希望它被發送到所有其他端點。這與 postman 的預期一致。但是,當涉及到瀏覽器時,我似乎無法讓它記住 cookie,甚至無法將其發送到其他端點。
使用端點的 js 範例
async function getDataWithQuery(query, schema){ let raw = `{"query":"${query}", "schema":"${schema}"}`; let requestOptions = { method: 'POST', body: raw, redirect: 'follow', }; try{ let dataJson = await fetch("http://localhost:8080/query/", requestOptions) data = await dataJson.json(); }catch(error){ console.log(error); } return data; }
我嘗試在 golang 中設定 samesite
屬性,或在 js 中使用 credential: "include"
等答案,但沒有成功。
解決方法
感謝評論中的討論,我找到了一些有關該問題的提示。
儲存 cookie(api 和前端位於同一主機上)
我使用document.cookie
來儲存cookie。我手動設定選項,因為在 api fetch
的回應上呼叫 res.cookie
僅傳回值。一個例子是 document.cookie = `gocookie=${res.cookie};路徑=/;網域=localhost;
。
發送cookie
#這個問題已經在先前的問題中回答過,並在評論中再次回答。問題是我使用了 credential:'include'
而不是正確的 credentials:'include'
(複數)。
cors 和 cookie
如果 api 和前端不在同一台主機上,您將必須同時修改 api 和前端。
前端
cookie 必須具有 api 的網域,因為是 api 需要它,而不是前端。因此,出於安全原因,您無法為另一個網域(前端)的網域(api)設定 cookie。解決方案是將使用者重定向到 api 端點,該端點在回應標頭中傳回 set-cookie
標頭。此解決方案指示瀏覽器使用附加的網域(api 的網域,因為 api 發送了它)來註冊該 cookie。
此外,您仍然需要在前端包含 credentials:'include'
。
api
您需要設定一些標頭。我設定的是
w.header().set("access-control-allow-origin", frontendorigin) w.header().set("access-control-allow-credentials", "true") w.header().set("access-control-allow-headers", "content-type, withcredentials") w.header().set("access-control-allow-methods", method) // use the endpoint's method: post, get, options
您需要公開前端將重定向使用者並在回應中設定 cookie 的端點。您可以省略它,而不是手動設定 api 的網域,瀏覽器會自動用網域填充它。
要處理cors 並讓js 成功傳送cookie,您必須在cookie 中設定samesite=none
和secure
屬性,並透過https 提供api(為了簡單起見,我使用了ngrok)。
像這樣
func SetCookie(w *http.ResponseWriter, email string) string { val := uuid.NewString() http.SetCookie(*w, &http.Cookie{ Name: "goCookie", Value: val, SameSite: http.SameSiteNoneMode, Secure: true, Path: "/", }) // rest of the code }
我建議您也閱讀使用 localstorage
和 document.cookie
之間的區別,這是我遇到的問題之一。
希望這有幫助。
以上是瀏覽器不儲存Golang後端發送的cookie的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

OpenSSL,作為廣泛應用於安全通信的開源庫,提供了加密算法、密鑰和證書管理等功能。然而,其歷史版本中存在一些已知安全漏洞,其中一些危害極大。本文將重點介紹Debian系統中OpenSSL的常見漏洞及應對措施。 DebianOpenSSL已知漏洞:OpenSSL曾出現過多個嚴重漏洞,例如:心臟出血漏洞(CVE-2014-0160):該漏洞影響OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻擊者可利用此漏洞未經授權讀取服務器上的敏感信息,包括加密密鑰等。

後端學習路徑:從前端轉型到後端的探索之旅作為一名從前端開發轉型的後端初學者,你已經有了nodejs的基礎,...

在BeegoORM框架下,如何指定模型關聯的數據庫?許多Beego項目需要同時操作多個數據庫。當使用Beego...

Go語言中用於浮點數運算的庫介紹在Go語言(也稱為Golang)中,進行浮點數的加減乘除運算時,如何確保精度是�...

Go爬蟲Colly中的Queue線程問題探討在使用Go語言的Colly爬蟲庫時,開發者常常會遇到關於線程和請求隊列的問題。 �...

GoLand中自定義結構體標籤不顯示怎麼辦?在使用GoLand進行Go語言開發時,很多開發者會遇到自定義結構體標籤在�...

Go語言中字符串打印的區別:使用Println與string()函數的效果差異在Go...

Go語言中使用RedisStream實現消息隊列時類型轉換問題在使用Go語言與Redis...
