golang
已收录文章:1296篇
-
gRPC-Web代理是前端与Go后端gRPC服务通信的关键桥梁,它将浏览器的HTTP/1.1请求转换为gRPC后端的HTTP/2协议,实现协议转换、CORS处理和双向兼容,确保前端可通过生成的客户端桩安全调用强类型的gRPC服务。284 收藏
-
使用Go标准库net/http实现文件上传,通过ParseMultipartForm解析表单,FormFile获取文件句柄,保存到服务器指定目录,同时支持前端HTML表单提交,完整示例包含错误处理与文件路径安全校验。153 收藏
-
Golang的archive/zip库通过zip.Writer和zip.Reader实现ZIP文件的压缩与解压,压缩时需为每个文件创建zip.FileHeader并写入相对路径以保留目录结构,解压时需校验路径防止ZipSlip漏洞;处理大文件时依赖流式I/O避免内存溢出,但需注意磁盘I/O、CPU消耗及小文件数量带来的性能瓶颈,可通过调整压缩级别、并发处理和缓冲区优化提升效率;常见错误包括文件I/O失败、ZIP格式无效、路径安全风险等,应全面检查错误、包装错误信息、验证路径合法性并确保资源及时释放。241 收藏
-
拆分Go包的核心是按职责边界将代码重构为高内聚、低耦合的子包,通过创建子目录、调整package声明和导入路径实现。拆分能提升可维护性与编译效率,合理使用接口和公共包可避免循环依赖,但需警惕过度拆分导致的认知负担与依赖复杂化,应以清晰职责划分而非文件大小为拆分依据。103 收藏
-
采用模块化结构提升可维护性,结合功能或DDD分层;2.用viper管理配置,环境变量注入敏感信息;3.使用zap等结构化日志并集成Prometheus与追踪系统;4.实现健康检查探针与优雅关闭;5.多阶段Docker构建轻量镜像,CI/CD集成静态检查与安全扫描;6.规范错误处理与重试熔断机制;7.通过context与并发控制优化资源使用。364 收藏
-
GolanggRPC服务的反射与动态调用通过protoreflect解析.proto文件获取服务信息,利用reflect包动态创建请求参数(支持嵌套message),结合context实现超时控制和错误处理,并通过Interceptor机制实现Token或TLS认证授权,从而在无需预生成代码的情况下实现灵活、安全的通用gRPC客户端调用。333 收藏