反向代理
反向代理是一种服务器架构,它接收来自客户端的请求并将其转发到后端的一个或多个服务器。与正向代理(代表客户端)不同,反向代理代表服务器端工作。
反向代理的主要优势:
- 负载均衡:分散请求到多个服务器
- 安全性提升:隐藏真实服务器信息
- 内容缓存:提高性能
- 路径重写与转发:灵活地路由请求
Salvo 框架提供反向代理功能的中间件.
路径转发与规范化
当你使用 Router::with_path("api/{**rest}") 这类通配路由挂载代理时,默认转发路径是被捕获到的剩余路径。例如 upstream 配置为 http://backend 时,客户端请求 /api/users 会转发为 http://backend/users。如果后端服务本身也期望收到 /api 前缀,应该把前缀写进 upstream:
Proxy 在转发前会规范化字面量 . 和 .. 路径段。如果你把代理作为访问控制边界,并且后端可能再次 URL decode 路径,可以启用严格路径规范化:
严格模式会拒绝容易产生二次解释差异的 percent-encoded 路径字符,例如 %2e、%2f、%5c,以及再次 decode 后可能变成这些序列的 encoded percent。后端仍然应该自己验证并规范化路由和文件路径;严格模式的作用是减少代理和后端对同一路径理解不一致的风险。
示例代码