本文整理汇总了Golang中github.com/keep94/appcommon/session_util.UserIdSession类的典型用法代码示例。如果您正苦于以下问题:Golang UserIdSession类的具体用法?Golang UserIdSession怎么用?Golang UserIdSession使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了UserIdSession类的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: newSessionStoreWithUserId
func newSessionStoreWithUserId(sessionId string, userId int64) sessions.Store {
result := ramstore.NewRAMStore(900)
sessionData := make(map[interface{}]interface{})
s := session_util.UserIdSession{&sessions.Session{Values: sessionData}}
s.SetUserId(userId)
result.Data.Save(sessionId, sessionData)
return result
}
开发者ID:keep94,项目名称:appcommon,代码行数:8,代码来源:session_test.go
示例2: TestSessionClearAll
func TestSessionClearAll(t *testing.T) {
m := map[interface{}]interface{}{1: 2, 3: 4}
s := session_util.UserIdSession{&sessions.Session{Values: m}}
if len(m) != 2 {
t.Fatal("Expected 2 things in map")
}
s.ClearAll()
if len(m) != 0 {
t.Error("Expected map to be empty")
}
}
开发者ID:keep94,项目名称:appcommon,代码行数:11,代码来源:session_test.go
示例3: TestXsrfTokenHack
func TestXsrfTokenHack(t *testing.T) {
s := session_util.UserIdSession{&sessions.Session{Values: make(map[interface{}]interface{})}}
s.SetUserId(kUserId)
xsrfToken := s.NewXsrfToken("MyPage", kNow.Add(15*time.Minute))
if !s.VerifyXsrfToken(xsrfToken, "MyPage", kNow) {
t.Error("Expected token to verify")
}
if xsrfToken[10] != ':' {
t.Error("Expected field dlimiter in xsrf token")
}
xsrfExpire := xsrfToken[:10]
xsrfChecksum := xsrfToken[11:]
if s.VerifyXsrfToken("", "MyPage", kNow) {
t.Error("Missing token should not verify.")
}
if s.VerifyXsrfToken("garbage", "MyPage", kNow) {
t.Error("garbage token should not verify.")
}
if s.VerifyXsrfToken("garbage:with_field_delimiter", "MyPage", kNow) {
t.Error("garbage with field delimiter token should not verify.")
}
if s.VerifyXsrfToken(
xsrfExpire+":garbage_checksum", "MyPage", kNow) {
t.Error("token with garbage checksum should not verify.")
}
// Add one to expire in token but leave checksum the same.
expire, err := strconv.Atoi(xsrfExpire)
if err != nil {
t.Errorf("Error happened parsing timestamp %v", err)
}
regularToken := fmt.Sprintf("%d:%s", expire, xsrfChecksum)
hackedToken := fmt.Sprintf("%d:%s", expire+1, xsrfChecksum)
if !s.VerifyXsrfToken(regularToken, "MyPage", kNow) {
t.Error("Expected regular token to verify")
}
if s.VerifyXsrfToken(hackedToken, "MyPage", kNow) {
t.Error("Expected hacked token not to verify")
}
}
开发者ID:keep94,项目名称:appcommon,代码行数:39,代码来源:session_test.go
示例4: TestXsrfTokenNewUser
func TestXsrfTokenNewUser(t *testing.T) {
s := session_util.UserIdSession{&sessions.Session{Values: make(map[interface{}]interface{})}}
s.SetUserId(kUserId)
xsrfToken := s.NewXsrfToken("MyPage", kNow.Add(15*time.Minute))
if !s.VerifyXsrfToken(xsrfToken, "MyPage", kNow) {
t.Error("Expected token to verify")
}
s.SetUserId(kUserId + 1)
if s.VerifyXsrfToken(xsrfToken, "MyPage", kNow) {
t.Error("Expected token not to verify. Different user.")
}
s.SetUserId(kUserId)
if s.VerifyXsrfToken(xsrfToken, "MyPage", kNow) {
t.Error("Expected token not to verify. Secret should have changed.")
}
}
开发者ID:keep94,项目名称:appcommon,代码行数:16,代码来源:session_test.go
示例5: TestXsrfToken
func TestXsrfToken(t *testing.T) {
s := session_util.UserIdSession{&sessions.Session{Values: make(map[interface{}]interface{})}}
s.SetUserId(kUserId)
xsrfToken := s.NewXsrfToken("MyPage", kNow.Add(15*time.Minute))
if !s.VerifyXsrfToken(xsrfToken, "MyPage", kNow.Add(14*time.Minute)) {
t.Error("Expected token to verify")
}
if s.VerifyXsrfToken(
xsrfToken, "AnotherPage", kNow.Add(14*time.Minute)) {
t.Error("Expected token not to verify. Wrong page")
}
if s.VerifyXsrfToken(xsrfToken, "MyPage", kNow.Add(15*time.Minute)) {
t.Error("Expected token not to verify. Time expired")
}
}
开发者ID:keep94,项目名称:appcommon,代码行数:15,代码来源:session_test.go
示例6: TestSessionUserId
func TestSessionUserId(t *testing.T) {
s := session_util.UserIdSession{&sessions.Session{Values: make(map[interface{}]interface{})}}
s.SetUserId(kUserId)
s.SetLastLogin(kNow)
id, ok := s.UserId()
if !ok {
t.Error("Expected a UserId")
}
if id != kUserId {
t.Errorf("Expected %d, got %d", kUserId, id)
}
s.ClearUserId()
id, ok = s.UserId()
if ok {
t.Error("Did not expect a user Id.")
}
lastLogin, ok := s.LastLogin()
if !ok {
t.Error("Expected a last login")
}
if lastLogin != kNow {
t.Errorf("Expected %v, got %v", kNow, lastLogin)
}
s.ClearLastLogin()
_, ok = s.LastLogin()
if ok {
t.Error("Did not expect a last login.")
}
}
开发者ID:keep94,项目名称:appcommon,代码行数:33,代码来源:session_test.go
注:本文中的github.com/keep94/appcommon/session_util.UserIdSession类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论