首页 > 其他分享 >使用Golong轻松实现JWT身份验证

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

时间:2024-03-13 21:29:43浏览次数:25  
标签:err nil JWT jwt 身份验证 Go Golong

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

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,以增加安全性。

标签:err,nil,JWT,jwt,身份验证,Go,Golong
From: https://blog.csdn.net/m0_69824302/article/details/136692141

相关文章

  • Day40:安全开发-JavaEE应用&SpringBoot框架&JWT身份鉴权&打包部署JAR&WAR
    目录SpringBoot-身份鉴权-JWT技术SpringBoot-打包部署-JAR&WAR思维导图Java知识点功能:数据库操作,文件操作,序列化数据,身份验证,框架开发,第三方组件使用等.框架库:MyBatis,SpringMVC,SpringBoot,Shiro,Log4j,FastJson等技术:Servlet,Listen,Filter,Interceptor,JWT,AOP,反射机制待......
  • 【Django进阶】djangorestframework-jwt使用
    【Django进阶】djangorestframework-jwt使用  简介Jsonwebtoken(JWT),是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者......
  • JWT LL
     1、工作原理"""1)jwt=base64(头部).base(载荷payload).hash256(base64(头部).base(载荷).密钥)2)base64是可逆的算法、hash256是不可逆的算法3)密钥是固定的字符串,保存在服务器""" 2、drf-jwt官网http://getblimp.github.io/django-rest-framework-jwt/......
  • Gin框架中使用JWT认证
    JWT是什么JSONWebToken(JWT)是一个开放标准(RFC7519),它定义了一种紧凑、独立的方式,可以用JSON对象在双方之间安全地传输信息。由于经过了数字签名,因此这些信息是可以验证和信任的。JWT可以使用密钥(使用HMAC算法)或使用RSA或ECDSA的公钥/私钥对进行签名。尽管JW......
  • win共享盘出现用户名或密码错误,你不能访问此共享文件夹,因为你组织的安全策略阻止未经
     win10共享文件夹的创建、访问凭据一直提示“用户名或密码错误”的解决办法_输入你的凭据以连接到用户名和密码不正确-CSDN博客 https://blog.csdn.net/wxp353/article/details/127055846 如何解决“你不能访问此共享文件夹,因为你组织的安全策略阻止未经身份验证的来宾访......
  • jwt
    funcmain(){//生成tokenmaxAge:=60*60*24//或者用下面自定义claimclaims:=jwt.MapClaims{"value":&Student{Name:"musong"},"exp":time.Now().Add(time.Duration(maxAge)*time.Second).Unix(),}token......
  • 登录认证-引入(JWT令牌)
    //ArticleControllerpackagecom.di.bigevent.controller;importcom.di.bigevent.pojo.Result;importorg.springframework.web.bind.annotation.GetMapping;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframework.web.bind.anno......
  • Django项目中使用JWT身份验证
    一、什么是JWTJWT,全称是JSONWebToken,是一个开放标准(RFC7519),它定义了一种紧凑的、自包含的方式,用于在多方之间安全地传输JSON格式的信息。这些信息可以被验证和信任,因为它们是数字签名的。JWT由三部分组成:头部(Header)、负载(Payload)、签名(Signature),每部分之间以.分隔。JWT最常见......
  • FastAPI系列:jwt认证
    jwt认证1.头部Header,主要是对jwt元数据的描述{'alg':'HS256','typ':'JWT'}2.载荷playload,主要包含jwt信息需要传递的主体数据{'iss':'jack',#由jwt签发'sub':'jack',#该jwt面向的用户组,也称为主题......
  • .Net 6 WebAPI 使用JWT进行 授权认证配置
    .Net6WebAPI使用JWT进行授权认证1、安装组件(Nuget)Microsoft.AspNetCore.Authentication.JwtBearer2、Program.cs配置//授权认证(使用JWT)builder.Services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer(o=>{//私钥varsecretByte=Enco......