搜索
简帛阁>技术文章>go使用jwt例子

go使用jwt例子

go 中使用jwt

安装

go get github.com/dgrijalva/jwt-go/v4

github地址:https://github.com/dgrijalva/jwt-go

文档地址:https://pkg.go.dev/github.com/dgrijalva/jwt-go

来个例子

type myClaims struct {
	UserNmae string `json:"username"`
	jwt.StandardClaims
}

func main() {
	jwt_key := []byte("yingxiaozhu") // 加密key
	// 加密一个token
	claims := myClaims{
		UserNmae:       "颖小主",
		StandardClaims: jwt.StandardClaims{
			NotBefore: time.Now().Unix() - 60, // 一分钟之前开始生效
			ExpiresAt: time.Now().Unix() + 60 * 60 *2, // 两个小时后失效
			Issuer: "签发人", // 签发人
		},
	}
	token := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
	token_string, err := token.SignedString(jwt_key)
	if err != nil {
		fmt.Println(err.Error())
		return 
	}
	fmt.Println(token_string) // eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IumiluWwj-S4uyIsImV4cCI6MTY0OTk1NDkzOSwiaXNzIjoi562-5Y-R5Lq6IiwibmJmIjoxNjQ5OTQ3Njc5fQ.d8a24gGacP7Af_zy2NdUJvGO1-rHJENZXzV3dA_AESA
  
	// 解密token
  parseToken,err := jwt.ParseWithClaims(token_string, &myClaims{}, func(token *jwt.Token) (interface{}, error) {
		return jwtToken, nil
	})
	if err != nil {
		fmt.Println(err.Error())
	}

	fmt.Println(parseToken.Claims.(*myClaims).UserNmae) // 颖小主
  
}
JWT使用1jwt是什么?JWT是目前流行的跨域认证解决方案,其原理是将用户信息通过加密生成Token,每次请求服务端只需要使用保存的密钥验证Token的正确性,进而不用再保存任何Session数据,
JWT简介什么是JWT?官网:JSON网络令牌介绍(JWT)JsonWebTokne是一个开放标准(RFC7519),它定义了一种紧凑且自成一体的方式,以便将各方之间的信息安全地传输为JSON对象。
需要引入jwt依赖<dependency><groupId>comauth0</groupId><artifactId>javajwt</art
引言Jsonwebtoken(JWT)是一个开放标准(RFC7519),它定义了一种紧凑的、自包含的方式,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间
由于本来搭建的是基于gin+gomicro+etcd的微服务架构,生成token放在了用户服务,校验则放在了api网关,因此两边代码可能重复。其实也可以共用,懒得改了&x1f602;用户服务端pack
1准备gogetgithubcom/dgrijalva/jwtgogogetgithubcom/gingonic/gin2代码packagemainimport(errorsfmtgithubcom/
关于JWT是什么,大家可以看看官网,一句话介绍下:是可以实现服务器无状态的鉴权认证方案,也是目前最流行的跨域认证解决方案。要实现JWT认证,我们需要分成如下两个步骤客户端获取JWTtoken。服务器
关于JWT是什么,大家可以看看官网,一句话介绍下:是可以实现服务器无状态的鉴权认证方案,也是目前最流行的跨域认证解决方案。要实现JWT认证,我们需要分成如下两个步骤客户端获取JWTtoken。服务器
在laravel使用Token进行用户认证首先先安装拓展包composerrequiretymon/jwtauth05*然后在配置中注册Tymon\JWTAuth\Providers\JWTAuthS
为什么使用JWT?随着技术的发展,分布式web应用的普及,通过session管理用户登录状态成本越来越高,因此慢慢发展成为token的方式做登录身份校验,然后通过token去取redis中的缓存的用