是否可以在谷歌应用引擎上使用martini与数据存储的sessionauth?

时间:2014-06-03 09:18:18

标签: google-app-engine session go google-cloud-datastore martini

我尝试在Google应用引擎上使用sessionauthmartini示例,并希望在数据存储区中保存登录列表,但不知道如何处理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)
}

1 个答案:

答案 0 :(得分: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.NewCookieStore替换为gaesessions.NewDatastoreStore