go语言实现简单登陆样例

目录

1、代码实现样例:

2、postman调用,获取登陆后的token:


1、代码实现样例:

复制代码
package main

import (
	"net/http"
	"time"

	"github.com/dgrijalva/jwt-go"
	"github.com/gin-gonic/gin"
)

var (
	// 密钥,用于签署 JWT 令牌
	signingKey = []byte("secret")
)

// 用户信息
type User struct {
	Username string `json:"username"`
	Password string `json:"-"`
}

// 模拟用户数据
var users = map[string]User{
	"user1": {"user1", "password1"},
	"user2": {"user2", "password2"},
}

// 登录处理程序
func LoginHandler(c *gin.Context) {
	var credentials struct {
		Username string `json:"username"`
		Password string `json:"password"`
	}
	if err := c.BindJSON(&credentials); err != nil {
		c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid request"})
		return
	}

	// 检查用户名和密码
	user, ok := users[credentials.Username]
	if !ok || user.Password != credentials.Password {
		c.JSON(http.StatusUnauthorized, gin.H{"error": "Invalid username or password"})
		return
	}

	// 创建 JWT 令牌
	token := jwt.New(jwt.SigningMethodHS256)
	claims := token.Claims.(jwt.MapClaims)
	claims["username"] = user.Username
	claims["exp"] = time.Now().Add(time.Hour * 24).Unix() // 令牌过期时间为24小时

	// 签名令牌
	tokenString, err := token.SignedString(signingKey)
	if err != nil {
		c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to generate token"})
		return
	}

	// 返回令牌给客户端
	c.JSON(http.StatusOK, gin.H{"token": tokenString})
}


func main() {
	r := gin.Default()

	// 登录路由
	r.POST("/login", auth2.LoginHandler)

	// 启动服务
	r.Run(":8080")
}

2、postman调用,获取登陆后的token:

相关推荐
喜欢吃燃面2 分钟前
C++:list(1)list的使用
开发语言·c++·学习
wenb1n6 分钟前
【安全漏洞】隐藏在HTTP请求中的“隐形杀手”:Host头攻击漏洞深度剖析
java·后端
snakeshe10106 分钟前
Java开发中的最佳实践与代码优化技巧
后端
不失者7 分钟前
关于AI时代的一点思考
人工智能·后端·程序员
好奇心笔记7 分钟前
D1数据库实战:SQLite在云端的华丽转身
人工智能·后端
Ray668 分钟前
es-plugin:lock:mmap+mlock
后端
snakeshe101012 分钟前
H2数据库入门指南:从建库到操作的全流程实践
后端
字节跳跃者13 分钟前
SpringBoot AOP + Redis 延时双删功能实战
java·后端
枫昕柚14 分钟前
python
开发语言·python
一只叫煤球的猫17 分钟前
你真的处理好 null 了吗?——11种常见但容易被忽视的空值处理方式
java·后端·面试