使用Golong轻松实现JWT身份验证

9,941次阅读
没有评论

共计 1986 个字符,预计需要花费 5 分钟才能阅读完成。

JSON Web Tokens (JWT) 是一种流行的安全方法,用于在两个方之间表示声明。在 Web 应用程序领域,它们通常用作从客户端向服务器传输身份信息(声明)的方式。本教程将引导您逐步实现 Go 应用程序中的 JWT 身份验证过程。

1_30aoNxlSnaYrLhBT0O1lzw

什么是 JWT?

JSON Web Token (JWT) 是一种紧凑且 URL 安全的方式,用于在两个方之间传输声明。JWT 中的声明被编码为一个 JSON 对象,并使用 JSON Web Signature (JWS) 进行数字签名。

JWT 通常的格式为:xxxxx.yyyyy.zzzzz

  • 头部:头部(xxxxx)通常由两部分组成:令牌类型 JWT 和签名算法。
  • 负载:负载(yyyyy)包含了声明。声明是关于主题(用户)的陈述。
  • 签名:要创建签名(zzzzz)部分,您需要使用编码后的头部、编码后的负载、一个密钥以及头部中指定的算法进行签名。

Go 环境设置

首先,您需要一个用于在 Go 中处理 JWT 的软件包。我们将使用 github.com/golang-jwt/jwt 软件包。[1]

在 Go 中生成 JWT

让我们创建一个生成 JWT 的函数:

package main

import (
 "fmt"
 "github.com/golang-jwt/jwt/v4"
 "time"
)
var mySigningKey = []byte("secretpassword")
func GenerateJWT() (string, error) {token := jwt.New(jwt.SigningMethodHS256)
 claims := token.Claims.(jwt.MapClaims)
 claims["authorized"] = true
 claims["user"] = "John Doe"
 claims["exp"] = time.Now().Add(time.Minute * 30).Unix()
 tokenString, err := token.SignedString(mySigningKey)
 if err != nil {fmt.Errorf("Something went wrong: %s", err.Error())
  return "", err
 }
 return tokenString, nil
}

在 Go 中验证 JWT

现在,让我们验证 JWT:

func ValidateToken(tokenString string) (*jwt.Token, error) {token, err := jwt.Parse(tokenString, func(token *jwt.Token) (interface{}, error) {if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {return nil, fmt.Errorf("There was an error")
  }
  return mySigningKey, nil
 })

 if err != nil {return nil, err}
 return token, nil
}

在 Go Web 应用程序中使用 JWT 进行身份验证

以下是一个简单示例,在 Go 的 HTTP 服务器中集成了 JWT 生成和验证:

package main

import (
 "fmt"
 "log"
 "net/http"
)

func HomePage(w http.ResponseWriter, r *http.Request) {validToken, err := GenerateJWT()
 if err != nil {fmt.Fprintf(w, err.Error())
 }
 clientToken := r.Header.Get("Token")
 if clientToken != validToken {w.WriteHeader(http.StatusUnauthorized)
  fmt.Fprintf(w, "Token is not valid")
  return
 }
 fmt.Fprintf(w, "Hello, World!")
}

func handleRequests() {http.HandleFunc("/", HomePage)
 log.Fatal(http.ListenAndServe(":9000", nil))
}

func main() {handleRequests()
}

使用此设置:

  • 服务器在访问主页时创建一个 JWT。
  • 要进行验证,客户端需要在标头“Token”中发送相同的 JWT。
  • 这只是一个基本示例。在实际情况中,您会在登录后生成一个令牌,并在每个需要身份验证的请求上进行检查。

总结

JWT 提供了一种强大而灵活的方法来处理 Web 应用程序中的身份验证和授权。在 Go 中,借助像 github.com/golang-jwt/jwt[2] 这样的软件包,实现基于 JWT 的身份验证非常简单。但请记住,始终保持您的签名密钥保密,并在生产应用程序中使用安全的方法,最好是 RSA,以增加安全性。

原文地址: 使用 Golong 轻松实现 JWT 身份验证

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于2024-09-19发表,共计1986字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)