了解helmet的使用

Helmet是什么?

helmetexpress的中间件,通过设置各种header来为express应用提供安全保护。虽然不能完全杜绝安全问题,但确实能提供某种程度的保护。

快速上手

helmet的使用非常简单。首先使用npm安装helmet

 
  1. npm install helmet --save

  2. 复制代码

其次在express应用中使用该中间件:

 
  1. const express = require('express')

  2. const helmet = require('helmet')

  3.  
  4. const app = express()

  5.  
  6. app.use(helmet())

  7. 复制代码

helmet包含了多个中间件,每个中间件既可以单独使用,也可以通过helmet()集中配置。以是否禁用缓存的noCache中间件为例:

单独使用中间件:

 
  1. app.use(helmet.noCache());

  2. 复制代码

helmet函数中配置:

 
  1. app.use(helmet({

  2. noCache: true

  3. }));

  4. 复制代码

我们接下来分别看一下几个主要的中间件的作用.

hidePoweredBy

攻击者可以针对X-Powered-By中暴露的服务器语言的漏洞进行攻击。

hidePoweredBy可以隐藏或混淆响应头中的X-Powered-By字段以迷惑攻击者。

 
  1. app.use(helmet.hidePoweredBy());

  2. 复制代码

也可以通过设置假的字段值来欺骗攻击者:

 
  1. app.use(helmet.hidePoweredBy({setTo: 'PHP 4.2.0'}));

  2. 复制代码

frameguard

攻击者骗取用户点击一个以iframe的方式隐藏的页面,来获取用户的信息。

frameguard通过设置x-frame-options来允许iframe的域。

 
  1. app.use(helmet.frameguard({action: 'deny'}));

  2. 复制代码

xssFilter

设置X-XSS-Protection提供基本的XSS防护,避免基本的反射性XSS攻击。

 
  1. // Sets "X-XSS-Protection: 1; mode=block".

  2. app.use(helmet.xssFilter());

  3. 复制代码

noSniff

如果响应头中Content-Type没有指定,浏览器默认会自动尝试识别响应体的内容以正确解析响应的文件。

设置 X-Content-Type-Optionsnosniff后,浏览器不再进行自动识别。这意味着响应的文件类型如果与Content-Type中声明的不一致,将会被浏览器屏蔽掉。

 
  1. app.use(helmet.noSniff());

  2. 复制代码

ieNoOpen

有些站点可能提供了HTML文件的下载,部分IE浏览器中,该文件会在站点的上下文打开,存在脚本注入的风险。

设置X-Download-Optionsnoopen不允许在在站点的上下文打开下载的HTML文件。

 
  1. app.use(helmet.ieNoOpen());

  2. 复制代码

hsts

设置Strict-Transport-Security告知用户在一定的时间段使用https访问。防止降级攻击和cookie劫持。

如下设置未来的90天内只使用https访问。

 
  1. app.use(helmet.hsts({maxAge: 7776000}));

  2. 复制代码

dnsPrefetchControl

dns-prefetch在提升网站性能的同时,潜在地会导致用户隐私泄露、dns服务过载、页面统计失真等问题。

dnsPrefetchControl通过将X-DNS-Prefetch-Control设置为off禁止浏览器进行DNS预解析。

 
  1. app.use(helmet.dnsPrefetchControl())

  2. 复制代码

app.use(helmet.contentSecurityPolicy()); // 内容安全策略
app.use(helmet.dnsPrefetchControl()); // dns预读取控制
app.use(helmet.expectCt()); // 证书透明度 (Certificate Transparency),防止错误签发的网站证书的使用不被察觉
app.use(helmet.frameguard()); // iframe访问策略,预防点击劫持
app.use(helmet.hidePoweredBy()); // 隐藏`X-Powered-By`头信息
app.use(helmet.hsts()); // HTTP严格传输安全协议(HTTP Strict Transport Security)
app.use(helmet.ieNoOpen()); // IE8特有,强制保存潜在不安全的下载
app.use(helmet.noSniff()); // 禁止嗅探MIME类型
app.use(helmet.permittedCrossDomainPolicies()); // 访问源策略控制
app.use(helmet.referrerPolicy()); // 引用策略
app.use(helmet.xssFilter()); // cross site script跨站脚本过滤

总结

以上简单介绍了helmet的用法和几个默认开启的中间件。helmet通过添加各种响应头来提供基本的安全防护。剩余未介绍到的中间件可以查阅其官方文档。

相关资源:前端开源库-koa-helmet

参考资料:https://blog.csdn.net/weixin_34367257/article/details/88029619

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值