哈喽!大家好,很高兴又见面了,我是编程网的一名作者,今天由我给大家带来一篇《Cookie 未使用 golang 设置》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转
哈喽!大家好,很高兴又见面了,我是编程网的一名作者,今天由我给大家带来一篇《Cookie 未使用 golang 设置》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!
问题内容我有一个用于登录用户的 rest api,它在浏览器上为登录用户设置 cookie,并且运行良好。 问题是,当用户从注册 api 完成注册时,我想调用登录 api,这样当时一切都正常,但 cookie 没有设置到浏览器。
这是登录api:
var loginviaDjangoapishim = Http.handlerfunc(func(w http.responsewriter, r *http.request) {
var t loginpost
var oldcookietoken string
decoder := JSON.newdecoder(r.body)
_:= decoder.decode(&t)
expiration := time.now().add(365 * 24 * time.hour)
flagtoreturn, cookie, _:= posttoapishim(t.username, t.passWord)
if flagtoreturn == "pass" {
cookietoken = generateoldcookie(authidfromusername.id)
newcookietoset := http.cookie{name: "ddagyeog", value: cookietoken , expires: expiration, domain: cookie_domain, path: "/", secure: false, httponly: true}
http.setcookie(w, &newcookietoset)
}
returnvalues := returnloginflag{flag: flagtoreturn, cookie: ""}
json.newencoder(w).encode(returnvalues)
})
此处注册 api:
var signupstart = http.handlerfunc(func(w http.responsewriter, r *http.request) {
var t startflowpost
decoder := json.newdecoder(r.body)
_:= decoder.decode(&t)
insertintouser := insertmethod(t)
flag, _ := loginoncoppaandnoncoppauserssignup(t.username, t.password)
log.println(flag)
json.newencoder(w).encode(flag)
})
下面是 loginoncoppaandnoncoppauserssignup
,它在注册用户后调用登录 api。
func loginOnCoppaAndNonCoppaUsersSignup(userName, password string) (flag returnSignUpFlaGCoppa, err error) {
var loginFlag returnLoginFlag
var jsonStr = []byte(`{
"username":"` + userName + `",
"password":"` + password + `"
}`)
request, _ := http.NewRequest("POST", USER_ROOT_URL+"login", bytes.NewBuffer(jsonStr))
request.Header.Set("Content-Type", "application/json")
client := &http.Client{}
response, _:= client.Do(request)
decoder := json.NewDecoder(response.Body)
if err = decoder.Decode(&loginFlag); err != nil {
return flag, err
}
if loginFlag.Flag == "pass" {
flag = returnSignUpFlagCoppa{Flag: "pass", Username: userName}
log.Println(flag)
} else {
flag := returnSignUpFlagCoppa{Flag: "error"}
log.Println(flag)
}
return flag, nil
}
在这里您可以从登录 url 响应中获取 cookie。
cookies := response.cookies()
然后您必须在注册 api 中再次使用 http.setcookie()
设置这些 cookie。请按照以下代码操作。
for _, cookie := range response.Cookies() {
http.SetCookie(w, cookie)
}
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持编程网!更多关于Golang的相关知识,也可关注编程网公众号。
--结束END--
本文标题: Cookie 未使用 Golang 设置
本文链接: https://www.lsjlt.com/news/596540.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0