1

我尝试在 google app engine 上使用martinisessionauth示例,并希望将登录列表保存在 Datastore 中,但不知道如何处理 appengine.Context。有没有人有经验?

谢谢你。

更新:

// Auth example is an example application which requires a login
// to view a private link. The username is "testuser" and the password
// is "password". This will require GORP and an SQLite3 database.
package ahl

import (
    //"fmt"
    "github.com/go-martini/martini"
    "github.com/hnakamur/gaesessions"
    "github.com/martini-contrib/binding"
    "github.com/martini-contrib/render"
    "github.com/martini-contrib/sessionauth"
    "github.com/martini-contrib/sessions"
    "net/http"
)

//var namespace string = "ahl"

func init() {
    //store := sessions.NewCookieStore([]byte("secret123"))
    store := gaesessions.NewDatastoreStore("", gaesessions.DefaultNonPersistentSessionDuration)

    m := martini.Classic()
    m.Use(render.Renderer())

    // Default our store to use Session cookies, so we don't leave logged in
    // users roaming around
    //store.Options(sessions.Options{
    //  MaxAge: 0,
    //})
    m.Use(sessions.Sessions("my_session", store))
    m.Use(sessionauth.SessionUser(GenerateAnonymousUser))
    sessionauth.RedirectUrl = "/new-login"
    sessionauth.RedirectParam = "new-next"

    m.Get("/", func(r render.Render) {
        r.HTML(200, "index", nil)
    })

    m.Get("/new-login", func(r render.Render) {
        r.HTML(200, "login", nil)
    })

    m.Post("/new-login", binding.Bind(MyUserModel{}), func(session sessions.Session, postedUser MyUserModel, r render.Render, req *http.Request) {
        // You should verify credentials against a database or some other mechanism at this point.
        // Then you can authenticate this session.
        //user := MyUserModel{}
        user := MyUserModel{1, "testuser", "password", false}
        //err := dbmap.SelectOne(&user, "SELECT * FROM users WHERE username = $1 and password = $2", postedUser.Username, postedUser.Password)
        //if err != nil {
        //  r.Redirect(sessionauth.RedirectUrl)
        //  return
        //} else {
        err := sessionauth.AuthenticateSession(session, &user)
        if err != nil {
            r.JSON(500, err)
        }

        params := req.URL.Query()
        redirect := params.Get(sessionauth.RedirectParam)
        r.Redirect(redirect)
        return
        //}
    })

    m.Get("/private", sessionauth.LoginRequired, func(r render.Render, user sessionauth.User) {
        r.HTML(200, "private", user.(*MyUserModel))
    })

    m.Get("/logout", sessionauth.LoginRequired, func(session sessions.Session, user sessionauth.User, r render.Render) {
        sessionauth.Logout(session, user)
        r.Redirect("/")
    })

    http.Handle("/", m)
}
4

1 回答 1

1

是的,这应该是可能的。sessionauth包需要你传递一个*sessions.Store,并且有一个 gaesessions 包可以替换默认的 cookie/文件存储:https ://github.com/hnakamur/gaesessions

sessionauth 包有一个完整的示例(https://github.com/martini-contrib/sessionauth/blob/master/example/auth_example.go) - 只需替换sessions.NewCookieStoregaesessions.NewDatastoreStore.

于 2014-06-03T12:14:51.517 回答