golang
已收录文章:428篇
-
Go语言通过crypto包实现AES和RSA加密解密:1.AES使用CBC模式和PKCS7填充,需密钥和IV,适合大量数据加密;2.RSA为非对称加密,公钥加密私钥解密,常用于密钥交换;3.实际应用推荐AES加密数据、RSA加密AES密钥的混合加密方案,注意密钥安全与填充模式选择。102 收藏
-
Golang通过内置godoc工具自动生成文档,解析源码注释并生成HTML页面,支持本地服务和命令行查询,强调文档与代码一致性,提升协作效率与可维护性。467 收藏
-
应缓存反射结果以减少重复解析,如将结构体字段信息存入映射复用,避免每次重新查找,从而显著提升性能。115 收藏
-
Golang实现JWT认证的核心是生成带用户身份信息的签名Token并验证其有效性,首先需使用github.com/golang-jwt/jwt/v5库定义包含用户ID、角色等信息并嵌入jwt.RegisteredClaims的自定义结构体MyClaims,接着通过HS256算法和密钥生成Token,再在后续请求中解析和验证Token的签名、过期时间及声明,确保请求合法性,该方式无状态且适合分布式系统,实际应用中常结合中间件从Authorization头提取Token进行验证,并将用户信息存入上下文供后续377 收藏
-
使用结构化日志和错误上下文提升Go系统可观测性,通过zap等库输出JSON格式日志,结合request_id串联请求链路,在错误传播中用errors.Wrap或%w包装添加上下文,并在统一入口记录日志,实现高效问题追踪。442 收藏
-
通过中间件和统一响应结构实现GoWeb错误处理,提升稳定性与可维护性;2.定义ErrorResponse结构体规范错误格式;3.ErrorMiddleware捕获panic并返回标准错误;4.封装writeError函数统一返回错误,确保前后端一致解析。204 收藏