Golang和JWT - 简单注销

时间:2016-03-29 18:59:08

标签: go token logout jwt

我目前正在研究API,经过一段时间后,我现在明白了如何在Go中使用JWT来获取令牌。使用此令牌,我可以保持用户连接,但是,如何从客户端应用程序注销?

这是我的token.go代码:

package main

import (
    "github.com/dgrijalva/jwt-go"
    "time"
)

const (
    tokenEncodeString = "something"
)

func createToken(user User) (string, error) {
    // create the token                                                                                                                                                                                  
    token := jwt.New(jwt.SigningMethodHS256)

    // set some claims                                                                                                                                                                                   
    token.Claims["username"] = user.Username;
    token.Claims["password"] = user.Password;
    token.Claims["exp"] = time.Now().Add(time.Hour * 72).Unix()

    //Sign and get the complete encoded token as string                                                                                                                                                  
    return (token.SignedString([]byte(tokenEncodeString)))
}

func parseToken(unparsedToken string) (bool, string) {
    token, err := jwt.Parse(unparsedToken, func(token *jwt.Token) (interface{}, error) {
            return []byte(tokenEncodeString), nil
    })

    if err == nil && token.Valid {
            return true, unparsedToken
    } else {
            return false, ""
    }
}

经过研究,我发现我可以使用黑名单,但我真的想知道是否可以使用更简单的东西,比如上面的代码。

我还想找到一个适用于JWT进程使用的内存的解决方案。一直断开/连接自己的人必须为每个会话只有一个令牌,而不是给他一个,给定黑名单中有一个。

1 个答案:

答案 0 :(得分:3)

首先:不要(永远)将敏感凭证放入令牌中。它们没有加密,您不应该这样做。

注意:

  • JWT是无国籍的:你发出一个,只要你在服务器上允许/正在验证它就会存在。
  • 您可以发布一个新的JWT,其过期时间为'now',但旧的JWT仍然有效(即存在安全风险)。
  • 通读http://jwt.io/introduction/

如果您需要在发布后控制过期访问令牌,那么您应该实施服务器端方案,这将允许您直接使令牌过期。用户只能拥有一个引用服务器端存储的ID。