Сессия Golang Gorilla не работает в браузере Chrome, но работает в Safari и Firefox - PullRequest
0 голосов
/ 19 ноября 2018

У меня проблемы с развертыванием веб-приложения golang на работающем сервере.

При локальном запуске этого кода он работал отлично.

Обратите внимание, что я выполнил следующие проверки, чтобы попытаться решить эту проблему:

  1. Я убедился, что в моем systemd есть переменная окружения SESSION_KEY. (Распечатал os.Getenv ("SESSION_KEY") и вернул ключ.

  2. Я попытался проверить все возвращенные ошибки из приведенных ниже функций. (Все ошибки равны нулю; однако, когда я пытаюсь получить get_session после факта, он возвращает false для переменной ok и 0 для uid)

  3. Я пытался работать с этим кодом в Firefox, Safari и Chrome. (Chrome - единственный, который не работает.)

Я только вытащил код, связанный с пакетом "github.com/gorilla/sessions".

var store = sessions.NewCookieStore([]byte(os.Getenv("SESSION_KEY")))


func init() {

	fmt.Println(store)
	fmt.Println("SESSION KEY BELOW: ", os.Getenv("SESSION_KEY"))

	store.Options = &sessions.Options{
	    Domain:   "buckler.solutions",
	    Path:     "/",
	    MaxAge:   3600 * 8, // 8 hours
	    HttpOnly: true,
	}
}

func get_session(request *http.Request) (int, error) {
	// META: Gets the session cookie and returns the result.

	session, err := store.Get(request, "session-name")
	fmt.Println("ERROR FROM store.Get: ", err)
	untyped_uid, untyped_ok := session.Values["uid"]
	fmt.Println("SESSIONUID before cast: ", untyped_uid)
	uid, ok := untyped_uid.(int)
	fmt.Println("SESSIONUID after cast: ", uid)

	if !untyped_ok || !ok {
		fmt.Println("GET SESSION ERRORS.")
		fmt.Println("UNTYPED_OK: ", untyped_ok)
		fmt.Println("OK: ", ok)
		return -1, errors.New("no session")
	} else {
		return uid, nil
	}
}

func set_session(response http.ResponseWriter, request *http.Request, uid int) {
	// META: Sets the session cookie and saves it.

	session, err := store.Get(request, "session-name")
	fmt.Println("SESSION in SET SESSION: ", session)
	fmt.Println("SESSION SET ERROR:", err)

	session.Values["uid"] = uid
	fmt.Println("UID: ", uid)

	err = session.Save(request, response)
	fmt.Println("SESSION SAVE ERROR:", err)
	
}

func clear_session(response http.ResponseWriter, request *http.Request) {
	// META: Clears the session so that it won't remember the user.

	session, err := store.Get(request, "session-name")
	fmt.Println("ERROR CLEARING SESSION: ", err)
	session.Values["uid"] = -1
	session.Save(request, response)
}

1 Ответ

0 голосов
/ 19 ноября 2018

Я думаю, что некоторая правильная обработка ошибок поможет вам быстро отладить вашу проблему и точно понять, в чем может быть проблема.

В Golang существует стандартная практика обработки ошибки сразу после ее объявления.Пример: в вашем методе get_session

session, err := store.Get(request, "session-name")
if err != nil {
   return -1, err
}

Проблема в вашем коде состоит в том, что вы не останавливаете выполнение, если возникает ошибка, из-за которой в 10 раз сложнее определить, где что-то могло пойти не так.

Иногда даже полезно (для отладки) добавлять небольшие комментарии, которые помогут вам даже более точно определить ошибку, например:

session, err := store.Get(request, "session-name")
if err != nil {
   fmt.Println("hey an error occurred trying to get the session: ",err.Error())
   return -1, err
}

Я думаю, что после того, как вы добавите должную обработку ошибок, вы сможете отладить вашу проблемубыстро.(И обрабатывать каждую ошибку, не игнорируйте)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...