Helmet
Helmet 可以通过适当设置 HTTP 响应头来帮助保护你的应用程序免受一些众所周知的 Web 漏洞。一般来说,Helmet 只是一组较小的中间件函数的集合,用于设置与安全相关的 HTTP 响应头(阅读更多)。
提示
请注意,将 helmet 应用为全局中间件或注册它必须在其他调用 app.use() 或可能调用 app.use() 的设置函数之前。这是因为底层平台(即 Express 或 Fastify)的工作方式,中间件/路由的定义顺序很重要。如果你在定义路由之后使用 helmet 或 cors 等中间件,那么该中间件将不会应用于该路由,它只会应用于中间件之后定义的路由。
在 Express 中使用(默认)
首先安装所需的包。
安装完成后,将其应用为全局中间件。
警告
当使用 helmet、@apollo/server (4.x) 和 Apollo Sandbox 时,Apollo Sandbox 上的 CSP 可能会出现问题。要解决此问题,请按如下所示配置 CSP:
在 Fastify 中使用
如果你使用 FastifyAdapter,请安装 @fastify/helmet 包:
fastify-helmet 不应作为中间件使用,而应作为 Fastify 插件使用,即使用 app.register():
:::warning 警告
当使用 apollo-server-fastify 和 @fastify/helmet 时,GraphQL playground 上的 CSP 可能会出现问题,要解决此冲突,请按如下所示配置 CSP:

