CSRF 防护

跨站请求伪造(CSRF 或 XSRF)是一种攻击类型,其中未经授权的命令从受信任的用户发送到 Web 应用程序。为了帮助防止这种情况,您可以使用 csrf-csrf 包。

与 Express 一起使用(默认)

首先安装所需的包:

$ npm i csrf-csrf

警告csrf-csrf 文档中所述,此中间件需要预先初始化会话中间件或 cookie-parser。请参阅文档以获取更多详细信息。

安装完成后,将 csrf-csrf 中间件注册为全局中间件。

import { doubleCsrf } from 'csrf-csrf';
// ...
// 在您的初始化文件中的某处
const {
  invalidCsrfTokenError, // 如果您计划创建自己的中间件,这纯粹是为了方便而提供的。
  generateToken, // 在您的路由中使用它来生成和提供 CSRF 哈希,以及令牌 cookie 和令牌。
  validateRequest, // 如果您计划制作自己的中间件,这也是一个便利功能。
  doubleCsrfProtection, // 这是默认的 CSRF 保护中间件。
} = doubleCsrf(doubleCsrfOptions);
app.use(doubleCsrfProtection);

与 Fastify 一起使用

首先安装所需的包:

$ npm i --save @fastify/csrf-protection

安装完成后,注册 @fastify/csrf-protection 插件,如下所示:

import fastifyCsrf from '@fastify/csrf-protection';
// ...
// 在注册某些存储插件后,在您的初始化文件中的某处
await app.register(fastifyCsrf);

警告@fastify/csrf-protection 文档这里所解释的,此插件需要首先初始化存储插件。请参阅该文档以获取进一步的说明。