浅析node应用的timing-attack安全漏洞


Posted in Javascript onFebruary 28, 2018

前言

假如你在项目中遇到过 eslint 报错 Potential timing attack ,不可忽视!这是一个涉及到安全的问题:时序攻击。
eslint 报错原因

首先eslint引入了一个叫做eslint-plugin-security的插件,这个插件有助于识别出潜在的安全问题,但同时也会产生误报的问题,附上插件 源码地址。

var keywords = '((' + [
  'password',
  'secret',
  'api',
  'apiKey',
  'token',
  'auth',
  'pass',
  'hash'
 ].join(')|(') + '))';

 var re = new RegExp('^' + keywords + '$', 'im');

 function containsKeyword (node) {
  if (node.type === 'Identifier') {
   if (re.test(node.name)) return true;
  }
  return
 }
 if (node.test.operator === '==' || node.test.operator === '===' || node.test.operator === '!=' || node.test.operator === '!==') {
  // 在这里 console 出错误
 }

首先这个插件会判断本次的运算符是否为 ==、===、!=、!==其中一种,其次检查标识符(字段名)是否包含特殊字符串password、secret、api、apiKey、token、auth、pass、hash,如果同时满足二者情况,eslint 就会编译报错 Potential timing attack。

攻击定义

timing attack:时序攻击,属于侧信道攻击 / 旁路攻击,侧信道攻击指的是利用信道外的信息,比如加解密的数据、数据比较时间、密文传输的流量和途径进行攻击的方式,相当于是“旁敲侧击”。

攻击点

首先讲讲js比较两个字符串大小的原理:

  • 判断字符串长度是否为0,如果为0,就可以直接比较出结果;反之,进入到第二步。
  • 字符串是由一个个字符组成,通过每个字符的charCode进行比较。
  • 在第二步中,只要出现一个字符不同,就 return false,剩余的字符不再做比较。

单个字符的比较是很快的,攻击者可以细化测量时间精度到微秒,通过响应时间的差异推算出是从哪一个字符开始不用的,这样一次次实验或者用 Python 写个脚本去跑,就可以试出正确的密码,密码破解的难度也降低了不少。

容易受攻击的写法

if (user.password === password) {
  return { state: true }; // 登录成功
 }

防御措施

每次不同的输入会造成处理时间的不同。为了防止它,我们需要使字符串比较花费相同的时间量,无论输入的密码是什么。
不容易受攻击的写法

系统中每一个密码的长度是固定的,每次比较密码是否相同时,使用正确密码的长度作为比较次数,使用异或比较每一个字符的 Unicode 编码是否相等,并且把每一次的比较结果存放到一个数组中,最后再判断数组的每一个元素是否为0(为 0 表示两个字符相同)。

// psdReceived 为用户输入密码;
 // psdDb 为系统中存储的正确用户密码
 const correctUser = (psdDb, psdReceived) => {
  const state = [];
  for (let i = 0; i < psdDb.length; ++i) {
   if (!psdReceived[i]) {
    state.push(false);
   } else {
    state.push(psdReceived.charCodeAt(i) ^ psdDb.charCodeAt(i));
   }
  }
  return state.length !== 0 && state.every(item => !item);
 }

三方包推荐

也可以使用 cryptiles 这个 npm 模块来解决这个问题

import cryptiles from 'cryptiles';

......
return cryptiles.fixedTimeCimparison(passwordFromDb, passwordReceived);
Javascript 相关文章推荐
小议javascript 设计模式 推荐
Oct 28 Javascript
JavaScript计算字符串中每个字符出现次数的小例子
Jul 02 Javascript
drag-and-drop实现图片浏览器预览
Aug 06 Javascript
AngularJS初始化静态模板详解
Jan 14 Javascript
Bootstrap编写一个兼容主流浏览器的受众门户式风格页面
Jul 01 Javascript
Angularjs处理页面闪烁的解决方法
Mar 09 Javascript
鼠标经过出现气泡框的简单实例
Mar 17 Javascript
JS实现禁止用户使用Ctrl+鼠标滚轮缩放网页的方法
Apr 28 Javascript
[js高手之路]图解javascript的原型(prototype)对象,原型链实例
Aug 28 Javascript
nginx配置React静态页面的方法教程
Nov 03 Javascript
详解如何在vue项目中引入elementUI组件
Feb 11 Javascript
详解Vue 数据更新了但页面没有更新的 7 种情况汇总及延伸总结
May 28 Javascript
vue组件传递对象中实现单向绑定的示例
Feb 28 #Javascript
在Vue组件中使用 TypeScript的方法
Feb 28 #Javascript
React组件中的this的具体使用
Feb 28 #Javascript
浅谈Vue网络请求之interceptors实际应用
Feb 28 #Javascript
Node.js中DNS模块学习总结
Feb 28 #Javascript
Vue自定义指令实现checkbox全选功能的方法
Feb 28 #Javascript
如何在vue中使用ts的示例代码
Feb 28 #Javascript
You might like
PHP基于GD库的缩略图生成代码(支持jpg,gif,png格式)
2014/06/19 PHP
PHP超全局数组(Superglobals)介绍
2015/07/01 PHP
微信公众号判断用户是否已关注php代码解析
2016/06/24 PHP
PHP多线程模拟实现秒杀抢单
2018/02/07 PHP
php实现将数据做成json的格式给前端使用
2018/08/21 PHP
PHP微信网页授权的配置文件操作分析
2019/05/29 PHP
用JTrackBar实现的模拟苹果风格的滚动条
2007/08/06 Javascript
仿迅雷焦点广告效果(JQuery版)
2008/11/19 Javascript
精心挑选的15个jQuery下拉菜单制作教程
2012/06/15 Javascript
JavaScript常用的返回,自动跳转,刷新,关闭语句汇总
2015/01/13 Javascript
jQuery自动完成插件completer附源码下载
2016/01/04 Javascript
浅谈jquery选择器 :first与:first-child的区别
2016/11/20 Javascript
微信小程序 页面跳转如何实现传值
2017/04/05 Javascript
web前端vue实现插值文本和输出原始html
2018/01/19 Javascript
element ui 对话框el-dialog关闭事件详解
2018/02/26 Javascript
Vue.js最佳实践(五招助你成为vuejs大师)
2018/05/04 Javascript
TypeScript的安装、使用、自动编译的实现
2020/04/10 Javascript
Python isinstance判断对象类型
2008/09/06 Python
Python编程给numpy矩阵添加一列方法示例
2017/12/04 Python
python安装模块如何通过setup.py安装(超简单)
2018/05/05 Python
浅谈Python大神都是这样处理XML文件的
2019/05/31 Python
Jacobi迭代算法的Python实现详解
2019/06/29 Python
python使用 request 发送表单数据操作示例
2019/09/25 Python
pyenv虚拟环境管理python多版本和软件库的方法
2019/12/26 Python
python opencv圆、椭圆与任意多边形的绘制实例详解
2020/02/06 Python
Python绘制组合图的示例
2020/09/18 Python
python 30行代码实现蚂蚁森林自动偷能量
2021/02/08 Python
CSS3正方体旋转示例代码
2013/08/08 HTML / CSS
美国时尚大码女装购物网站:Avenue
2019/05/24 全球购物
艺术应用与设计个人的自我评价
2013/11/23 职场文书
家长会演讲稿
2014/04/26 职场文书
七一建党节慰问信
2015/02/14 职场文书
公安机关起诉意见书
2015/05/20 职场文书
导游词之峨眉山
2019/12/16 职场文书
Python编写冷笑话生成器
2022/04/20 Python
Java Spring Lifecycle的使用
2022/05/06 Java/Android