Express.js 中使用 Helmet 的最佳实践

阅读时长 5 分钟读完

在构建 web 应用程序时,安全性通常是开发人员需要考虑的一个关键因素。使用 Express.js 框架开发 web 应用程序时,一个流行的工具是 Helmet,它可以帮助我们保障应用程序的安全性。但是,使用 Helmet 并不是百分之百安全的,需要一些最佳实践来确保应用程序的安全性和稳定性。

Helmet 简介

Helmet 是一个 Express.js 中间件,通过设置合适的 HTTP 头部来增加 web 应用程序的安全性。这些头部包括:

  • Content Security Policy (CSP):防止跨站点脚本攻击 (XSS)。
  • Cross-site Request Forgery (CSRF) 保护:防止 CSRF 攻击。
  • DNS Prefetching 控制:防止 DNS 欺骗攻击。
  • 禁用浏览器的特殊功能:比如 X-Powered-By 头部。
  • 隐藏 X-Powered-By 头部信息:不暴露 web 服务器的技术栈和版本信息。
  • 设置合适的 X-Content-Type-Options 头部:防止浏览器的 Mime 类型混淆攻击。
  • 设置合适的 X-Frame-Options 头部:防止点击劫持攻击。
  • 设置合适的 X-XSS-Protection 头部:启用浏览器的 XSS 保护。

安装 Helmet

使用 Helmert 极为简单,只需要使用 npm 一行代码来安装:

在项目的入口文件中添加以下代码引入 Helmet:

CSP

CSP 是一种安全策略,通过限制 web 页面中可执行的脚本源来减少 XSS 攻击的风险。CSP 的作用是确定来自哪些地址的资源可以被浏览器加载和执行。

在上面的代码中,default-src 表示默认资源来源,style-src 表示允许加载的 CSS 来源 URL。

CSRF 保护

CSRF 攻击是通过在已认证用户的浏览器上偷运行代码来实现的。为了在服务端验证 csrf 标签,我们需要使用第三方模块 nonce 来生成随机的 token,并将其存储在 cookie 中。

接着,在网页表单中添加如下 input 控件即可:

DNS prefetching 控制

DNS prefetching 是浏览器的一项功能,它可以提高网页的加载速度。但是,它也可能被用于进行 DNS 欺骗攻击,我们需要禁用这项功能来确保应用程序的安全性。

隐藏 X-Powered-By 头部

黑客可以利用 X-Powered-By 头部信息获得更多的关于 web 服务器技术栈和版本信息。为了保护我们的应用程序,我们需要隐藏这些信息。

设置 X-Content-Type-Options 头部

X-Content-Type-Options 头部可以让浏览器强制执行响应的 MIME 类型,防止浏览器的类型混淆攻击。

设置 X-Frame-Options 头部

X-Frame-Options 头部可以防止点击劫持攻击。设置这个头部后,浏览器会阻止加载任何 frame 或 iframe,只允许 loading 相同域中的窗口。

设置 X-XSS-Protection 头部

X-XSS-Protection 头部启用浏览器内置的 XSS 保护机制。通过在响应中包含 X-XSS-Protection 头部,保证浏览器激活内置的 XSS 过滤。

总结

使用 Helmet 可以轻松地增加 web 应用程序的安全性,但是它并不是固若金汤。通过上述最佳实践,我们可以加强我们的 Express.js 应用程序的安全性,从而保护用户的隐私和敏感数据。始终保持最新的安全技能和实践,以确保应用程序最高水平的稳定性和安全性。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6549eecb7d4982a6eb423ee3

纠错
反馈