0

0

Golang学习之Web服务端的认证与授权

PHPz

PHPz

发布时间:2023-06-24 09:04:05

|

1430人浏览过

|

来源于php中文网

原创

golang是一种新兴的语言,尤其适合实现web服务。在web服务中,认证和授权是很重要的安全机制。本文将介绍如何在golang中实现web服务端的认证与授权。

认证(Authentication)是指验证用户的身份,确定他是否有权访问资源。常见的认证方式包括用户名和密码、令牌(Token)等。授权(Authorization)是指决定用户是否具备访问某个资源的权限。通常包括基于角色(Role-based access control)和基于资源(Resource-based access control)的授权方式。

Golang中可以使用多种框架和库来实现Web服务的认证与授权。本文以Gin框架为例,介绍如何实现基于令牌的认证与基于角色的授权。

一、基于令牌的认证

在Gin框架中,可以使用JWT(Json Web Token)来实现基于令牌的认证。JWT是一种开放标准,定义了一种简洁、自包含的方式,用于在网络上安全地传输信息。JWT由三部分组成:头部(Header),载荷(Payload)和签名(Signature)。

立即学习go语言免费学习笔记(深入)”;

头部用于描述令牌的类型以及签名算法,例如:

{"alg": "HS256", "typ": "JWT"}

载荷用于存储需要传输的信息,例如用户名、角色等,例如:

{"sub": "123456789", "name": "John Doe", "iat": 1516239022}

签名则用于防止信息被篡改,需要使用私钥进行签名,例如:

HMACSHA256(
base64UrlEncode(header) + "." +
base64UrlEncode(payload),
secret)

在Golang中,可以使用github.com/dgrijalva/jwt-go库来实现JWT的生成和验证。例如:

// Create a new token object, specifying signing method and the claims you would like it to contain.
token := jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.MapClaims{

"sub": "1234567890",
"name": "John Doe",
"iat": 1516239022,

})

// Sign and get the complete encoded token as a string using the secret
tokenString, err := token.SignedString([]byte("secret"))

// Parse the token to verify its validity and extract the claims
token, err := jwt.ParseWithClaims(tokenString, &MyCustomClaims{}, func(token *jwt.Token) (interface{}, error) {

return []byte("secret"), nil

})

在Gin框架中,则可以使用gin-jwt库来快速构建基于JWT的认证机制。例如:

// Create a new JWT middleware with the specified signing key
middleware := jwtmiddleware.New(jwtmiddleware.Options{

mallcloud商城
mallcloud商城

mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提

下载
SigningMethod:   jwt.SigningMethodHS256,
Claims:          &CustomClaims{},
KeyFunc: func(token *jwt.Token) (interface{}, error) {
    // Check the signing method and return the key for verifying the signature
    if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {
        return nil, fmt.Errorf("unexpected signing method: %v", token.Header["alg"])
    }
    return []byte("secret"), nil
},

})

// Use the middleware in a Gin route to protect the resource
router.GET("/protected", middleware.MiddlewareFunc(), func(c *gin.Context) {

claims := jwtmiddleware.ExtractClaims(c)
user := claims["user"].(string)
c.JSON(200, gin.H{
    "user": user,
    "message": "Hello, World!",
})

})

二、基于角色的授权

在Gin框架中,可以使用基于角色的授权来限制用户对资源的访问。例如,在一个Blog应用中,使用角色来区分普通用户和管理员。管理员可以访问所有Blog资源,而普通用户只能访问自己发布的Blog资源。

可以使用gin-authz库来实现基于角色的授权。例如:

// Define the authorization middleware to enforce the role-based access
authMiddleware := authz.NewAuthorizer(authz.BuiltinRolebased())

// Define a role-based policy to grant the "admin" role access to all resources
adminRole := authz.NewRole("admin", []string{"*"})
policy := authz.NewPolicy()
policy.AddRole(adminRole)

// Use the policy middleware in a Gin route to enforce the role-based access control
router.GET("/blogs", authMiddleware.CheckPermission(policy, "admin"), func(c *gin.Context) {

// Return the list of all blogs

})

router.GET("/blog/:id", authMiddleware.CheckPermission(policy, "read"), func(c *gin.Context) {

// Return the specified blog

})

router.POST("/blog", authMiddleware.CheckPermission(policy, "write"), func(c *gin.Context) {

// Create a new blog

})

在上述代码中,定义了一个名为"admin"的角色,该角色具有对所有资源("*")的访问权限。然后,在每个路由中通过使用authMiddleware.CheckPermission函数来检查用户的角色是否具有对该资源的访问权限。

总结

本文介绍了在Golang中如何实现Web服务端的认证和授权。通过使用Gin框架和相关的库,我们可以快速构建安全、可靠的Web服务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

178

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

337

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

389

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

195

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

191

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

192

2025.06.17

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
golang socket 编程
golang socket 编程

共2课时 | 0.1万人学习

nginx浅谈
nginx浅谈

共15课时 | 0.8万人学习

golang和swoole核心底层分析
golang和swoole核心底层分析

共3课时 | 0.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号