中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

淺析node應用的timing-attack安全漏洞

發布時間:2020-08-19 15:50:22 來源:腳本之家 閱讀:123 作者:laozhang 欄目:web開發

前言

假如你在項目中遇到過 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);

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

庆云县| 维西| 内黄县| 宁安市| 廊坊市| 揭阳市| 木兰县| 田东县| 磴口县| 沙坪坝区| 徐汇区| 孟州市| 永兴县| 宜兰县| 北宁市| 上栗县| 龙游县| 海城市| 葫芦岛市| 东丽区| 阜新| 灵台县| 崇左市| 山东省| 潞城市| 江达县| 龙南县| 玛多县| 灵璧县| 甘泉县| 益阳市| 曲沃县| 桃源县| 凉城县| 樟树市| 定边县| 永清县| 东安县| 洛川县| 北辰区| 澳门|