我通过javascript设置了Cookie,例如:
setCookie("appointment", JSON.stringify({
appointmentDate: selectedDay.date,
appointmentStartMn: appointment.mnRange[0],
appointmentId: appointment.id || 0,
appointmentUserId: appointment.user.id || 0
})
);
设置cookie后,我要将用户重定向到预订页面:
window.location.href = "https://localhost:8080/booking/"
setCookie函数:
function setCookie(cookieName, cookieValue) {
document.cookie = `${cookieName}=${cookieValue};secure;`;
}
我想从go后端中检索该cookie,但是我不知道该怎么做。我已经读过有关此问题的信息,因为我以前从未使用过Cookie,但是答案似乎表明,除了设置document.cookie之外,我不必做其他事情。
在我的浏览器存储中,我可以看到cookie的设置确实符合预期。
在我的后端中,我要打印cookie:
r.HandleFunc("/booking/", handler.serveTemplate)
func (handler *templateHandler) serveTemplate(w http.ResponseWriter, r *http.Request) {
c, err := r.Cookie("appointment")
if err != nil {
fmt.Println(err.Error())
} else {
fmt.Println(c.Value)
}
}
//output http: named cookie not present
我想念的具体是什么?我认为我混淆了本地/ http cookie,但是如何实现读取客户端设置cookie?
更新(有关更多信息,请参见答案)
它与golang无关。我的:
appointmentDate: selectedDay.date
格式化为2019-01-01
和-
的字符不是可以发送到后端的有效字符。它可以在我的浏览器中使用,但是需要经过URI编码才能传递。
这就是窍门:
`${cookieName}=${encodeURIComponent(cookieValue)};secure;` + "path=/";`
然后就去(这里没有记错以节省空间):
cookie, _ := r.Cookie("appointment")
data, _ := url.QueryUnescape(cookie.Value)
答案 0 :(得分:1)
更好的方法是将json编码为base64。我做了一个有效的例子...
main.go
package main
import (
"encoding/base64"
"encoding/json"
"fmt"
"io"
"io/ioutil"
"net/http"
)
// Contains everything about an appointment
type Appointment struct {
Date string `json:"appointmentDate"` // Contains date as string
StartMn string `json:"appointmentStartMn"` // Our startMn ?
ID int `json:"appointmentId"` // AppointmentId
UserID int `json:"appointmentUserId"` // UserId
}
func main() {
handler := http.NewServeMux()
// Main request
handler.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
fmt.Printf("Requested /\r\n")
// set typical headers
w.Header().Set("Content-Type", "text/html")
w.WriteHeader(http.StatusOK)
// Read file
b, _ := ioutil.ReadFile("index.html")
io.WriteString(w, string(b))
})
// booking request
handler.HandleFunc("/booking/", func(w http.ResponseWriter, r *http.Request) {
fmt.Printf("Requested /booking/\r\n")
// set typical headers
w.Header().Set("Content-Type", "text/html")
w.WriteHeader(http.StatusOK)
// Read cookie
cookie, err := r.Cookie("appointment")
if err != nil {
fmt.Printf("Cant find cookie :/\r\n")
return
}
fmt.Printf("%s=%s\r\n", cookie.Name, cookie.Value)
// Cookie data
data, err := base64.StdEncoding.DecodeString(cookie.Value)
if err != nil {
fmt.Printf("Error:", err)
}
var appointment Appointment
er := json.Unmarshal(data, &appointment)
if err != nil {
fmt.Printf("Error: ", er)
}
fmt.Printf("%s, %s, %d, %d\r\n", appointment.Date, appointment.StartMn, appointment.ID, appointment.UserID)
// Read file
b, _ := ioutil.ReadFile("booking.html")
io.WriteString(w, string(b))
})
// Serve :)
http.ListenAndServe(":8080", handler)
}
index.html
<html>
<head>
<title>Your page</title>
</head>
<body>
Setting cookie via Javascript
<script type="text/javascript">
window.onload = () => {
function setCookie(name, value, days) {
var expires = "";
if (days) {
var date = new Date();
date.setTime(date.getTime() + (days*24*60*60*1000));
expires = "; expires=" + date.toUTCString();
}
document.cookie = name + "=" + btoa((value || "")) + expires + "; path=/";
}
setCookie("appointment", JSON.stringify({
appointmentDate: "20-01-2019 13:06",
appointmentStartMn: "1-2",
appointmentId: 2,
appointmentUserId: 3
})
);
document.location = "/booking/";
}
</script>
</body>
booking.html
<html>
<head>
<title>Your page</title>
</head>
<body>
Your booking is okay :)
</body>