0

我正在使用 martini-contrib 会话库编写一个网络应用程序。不过,我似乎遇到了问题。我的会话似乎没有在浏览器中的请求之间移动。

我已遵循示例代码中概述的确切准则,但我的代码不起作用。下面是相关部分:

登录页面:

 m.Get("/login", binding.Bind(LoginForm{}), func(r render.Render, session sessions.Session, form LoginForm) string {
    // Get info from the database.
    conn, err := sql.Open("sqlite3", "ocdns.db")
    defer conn.Close()

    // Prepare the statement.
    stmt, err := conn.Prepare(`
      SELECT user_id, username, name_first, name_last, role, team_id
      FROM User
      WHERE username = ? AND password = ?
      LIMIT 1;
    `)
    if err != nil {
      log.Fatal(err)
    }
    defer stmt.Close()

    // Query the database and set appropriate items if a row was actually returned.
    var id string
    var username string
    var name_first string
    var name_last string
    var role string
    var team_id string

    err = stmt.QueryRow(form.Username, form.Password).Scan(&id, &username, &name_first, &name_last, &role, &team_id)

    if err != nil {
      log.Print("!! Bad login from " + form.Username + " with " + form.Password)
      log.Fatal(err)
    } else {
      log.Print(">" + id + "<")
      log.Print(">" + username + "<")
      log.Print(">" + name_first + "<")
      log.Print(">" + name_last + "<")
      log.Print(">" + role + "<")
      log.Print(">" + team_id + "<")
      session.Set("id", id)
      session.Set("username", username)
      session.Set("name_first", name_first)
      session.Set("name_last", name_last)
      session.Set("role", role)
      session.Set("team_id", team_id)

      v := session.Get("name_first")
      if v == nil {
        log.Print("!! Uh oh.")
      }
      log.Print(v.(string))

      return "OK"
    }

    return "Bad"
  })

会话检查页面:

  m.Get("/session", func(session sessions.Session) string {
    var c Context

    i := session.Get("id")
    if i == nil {
      c.Id = -1
    }

    c.Id, _ = strconv.Atoi(i.(string))


    i = session.Get("username")
    if i == nil {
      log.Print("!! username")
    }

    if vs, ok := i.(string); ok {
      c.Username = vs
    } else {
      log.Print(vs)
    }

    log.Print(c)

    j, _ := json.Marshal(c)

    return string(j)
  })

上下文结构:

type Context struct {
  Id          int       `json:"id"`
  Username    string    `json:"username"`
  NameFirst   string    `json:"name_first"`
  NameLast    string    `json:"name_last"`
  Role        string    `json:"role"`
  TeamId      int       `json:"team_id"`
}

最后,我的会话声明:

// Create session store.
store := sessions.NewCookieStore([]byte("secret123"))
m.Use(sessions.Sessions("my_session", store))

我曾尝试清空缓存以使其正常工作,但它不会。我确实查看了 Chrome 的开发人员工具以查看是否正在使用存储,并且确实发现会话在两个页面之间移动,但session请求的输出是一个空的Contextjson 结构。

我需要弄清楚为什么我的会话数据在请求之间似乎丢失了,以及我可以做些什么来修复它。我看过这里,虽然没有什么适合我的确切问题,但我确实发现他们的 Web 服务器配置存在问题。

提前致谢!

4

1 回答 1

0

您应该如下更改您的第一个函数调用,以确保它必须在登录前首先进入会话。

m.Get("/login", SOME_FUNC_TO_SEESION, func(r render.Render, session sessions.Session, form LoginForm) string {

这是示例视频,希望对您有所帮助。您的代码应该运行良好。 https://gophercasts.io/lessons/8-auth-part-2

于 2015-05-28T09:10:30.930 回答