【Express.js】安全性

安全性

在 Web 应用中,安全亦是相当重要的一环,在正式的场景下,数据安全尤为重要。

使用高稳定版本的 Express

Express 2.x 和 Express 3.x 已不再维护,其中存在的安全性和性能问题不会得到修复,请尽可能的使用或迁移到 Express 4.x

使用 TLS

如果应用需要处理或传输敏感数据,请使用 TLS 来保护连接和数据,TLS 在客户端发起阶段对其加密,从而防止初步的黑客行为。

使用 Helmet

helmet.js 是一个 Express 中间件,用于设置 HTTP 标头来帮助 Express 应用免受一些常规的 Web 漏洞:

  • CSP 设置标头以防止跨站脚本攻击和注入,Content-Security-Policy
  • hidePoweredBy 删除 X-Powered-By 标头
  • hsts 设置强制与服务器建立安全连接(https)Strict-Transport-Security
  • noCachePragma 禁用客户端缓存 Cache-Control
  • noSniff 设置以防止浏览器从声明内容类型嗅探响应的 MIME
  • frame 设置以防止点击劫持 X-Frame-Options
  • xssFilter 设置以禁用 XSS 缺陷脚本 X-XSS-Protection

使用方法:

shell 复制代码
npm install helmet --save

挂载到 app:

javascript 复制代码
const helmet = require("helmet")();

app.use(helmet);

为确保 Cookie 不会打开您的应用而受攻击,请不要使用默认 Cookie 会话名称:

javascript 复制代码
const Session = require("express-session");

app.set("trust proxy", 1);
app.use(Session({
  secret: 'express-demo',
  name: 'sessionX'
}));

此外,设置一些安全选项来确保 Session 安全:

javascript 复制代码
app.use(Session({
  name: "sessionX",
  keys: ["evp-key-1", "evp-key-2"],
  cookie: {
    secure: true,
    httpOnly: true,
    domain: 'express-demo.com',
    path: 'security',
    expires: new Date(Date.now() + 60 * 60 * 1000) // 1 hour
  }
}));

争对暴力攻击的端点保护

如争对同一用户或同一IP的短期内大量失败行为进行监测,进行适当的用户封禁和IP封禁。

rate-limiter-flexible 提供了相关的技术支持,文档详见此处

确保依赖安全

您正在使用的 npm 包也许存在安全漏洞,你可以使用 npm audit 来分析依赖树,并通过 npm audit fix 进行简单的修复,如果你想要更精细的控制依赖安全,可以尝试一下 snyk.js:

  • 安装
shell 复制代码
npm install -g snyk
  • 检测漏洞
shell 复制代码
synk test
  • 引导修复
shell 复制代码
synk wizard

其它注意事项

以下是优秀的Node.js 安全检查表中的一些进一步建议。有关这些建议的所有详细信息,请参阅该博客文章:

  • 使用csurf中间件防止跨站点请求伪造(CSRF)。
  • 始终筛选和清理用户输入,以防止跨站点脚本 (XSS) 和命令注入攻击。
  • 使用参数化查询或预准备语句防御 SQL 注入攻击。
  • 使用开源sqlmap工具检测应用中的 SQL 注入漏洞。
  • 使用nmapsslyze工具测试 SSL 密码、密钥和重新协商的配置以及证书的有效性。
  • 使用安全正则表达式确保您的正则表达式不容易受到正则表达式拒绝服务攻击。

下一节-健康检查

相关推荐
Craaaayon18 小时前
如何选择两种缓存更新策略(写缓存+异步写库;写数据库+异步更新缓存)
java·数据库·redis·后端·缓存·mybatis
视图猿人18 小时前
RxJS基本使用及在next.js中使用的例子
开发语言·javascript
墨雪不会编程18 小时前
C++的基础语法篇一 ——命名空间
开发语言·c++
墨客希18 小时前
安装 awscli
开发语言
bitbitDown19 小时前
从零打造一个 Vite 脚手架工具:比你想象的简单多了
前端·javascript·面试
天天进步201519 小时前
Python全栈项目:结合Puppeteer和AI模型操作浏览器
开发语言·人工智能·python
唐僧洗头爱飘柔952719 小时前
【GORM(3)】Go的跨时代ORM框架!—— 数据库连接、配置参数;本文从0开始教会如何配置GORM的数据库
开发语言·数据库·后端·golang·gorm·orm框架·dsn
Jonathan Star19 小时前
在 Go 语言中,模板字符串
开发语言·后端·golang
闲人编程19 小时前
用Python识别图片中的文字(Tesseract OCR)
开发语言·python·ocr·识图·codecapsule
程序员卷卷狗19 小时前
JVM 内存结构与 GC 调优全景图
java·开发语言·jvm