关于前端:用一个小故事来揭秘js加密的神秘面纱

49次阅读

共计 2146 个字符,预计需要花费 6 分钟才能阅读完成。

在夜幕降临的时刻,当人们汇集在一起分享民间鬼故事的时候,总有一种神秘的气氛洋溢在空气中。而明天,我将与你分享一个不同寻常的民间鬼故事,这个故事中暗藏着一段神秘的 JS 加密代码,让咱们一起揭开它背地的魔法!

这个鬼故事产生在一个古老的村庄,传说中有一个被咒骂的房子,据说住在那里的人会受到恶魔的困扰。有一天,一位怯懦的年轻人,名叫小杰,决定勇闯这个鬼屋,解开其中的谜题。当他进入房间时,他发现了一张古老的纸条,下面写着一段通过 JS 加密的代码。

那段 JS 加密代码看起来像这样:

var encryptedMessage = "jotjef!uijol!gps!b!tuspoh!b!fyusfnfou/!jotjef!jnbhf-!jotjef!dpnqfot!uif!dpogfuz-!xjui!jotjef!b!gjstu!hvufo!up!jt!b!jefb;!jotjef!jnbhf-!xjui!jotjef!b!mjof;!jotjef!jnbhf-!xjui!jotjef!b!cfuu;!jotjef!jnbhf-!xjui!jotjef!b!opof;!jotjef!jnbhf-!xjui!jotjef!b!ifbw;!jotjef!jnbhf-!xjui!jotjef!b!mjtu;!jotjef!jnbhf-!xjui!jotjef!b!wpje;!jotjef!jnbhf-!xjui!jotjef!b!usbjo;!jotjef!jnbhf-!xjui!jotjef!b!xf;!jotjef!jnbhf-!xjui!jotjef!b!gmvpsfe;!jotjef!jnbhf-!xjui!jotjef!b!nbmm!jnbhfe;!jotjef!jnbhf-!xjui!jotjef!b!gjstu!jefb;!jotjef!jnbhf-!xjui!jotjef!b!gjstu!ofx;!jotjef!jnbhf-!xjui!jotjef!b!gjstu!gmvpsfe;!jotjef!jnbhf-!xjui!jotjef!“;

小杰紧紧握着那张纸条,心中充斥了好奇和刺激。他晓得这段加密的 JS 代码将为他解开鬼屋的谜团提供线索。于是,他开始认真钻研这段代码。

通过一番推敲,小杰意识到这段加密代码是通过将字母向后挪动一位来实现的。于是,他入手批改了代码,将每个字母向前挪动一位,并从新运行了程序。

批改后的代码如下所示:

// 创立替换映射表
function createSubstitutionMap(key) {let substitutionMap = {};
  for (let i = 0; i < key.length; i++) {substitutionMap[String.fromCharCode("a".charCodeAt(0) + i)] = key[i];
  }
  return substitutionMap;
}

// 加密数据
function encryptSubstitution(data, substitutionMap) {
  let encryptedData = "";
  for (let i = 0; i < data.length; i++) {let char = data[i];
    if (char.match(/[a-zA-Z]/)) {let substitutionChar = substitutionMap[char.toLowerCase()];
      let encryptedChar = char === char.toLowerCase() ? substitutionChar : substitutionChar.toUpperCase();
      encryptedData += encryptedChar;
    } else {encryptedData += char;}
  }
  return encryptedData;
}

// 解密数据
function decryptSubstitution(encryptedData, substitutionMap) {let decryptionMap = {};
  for (let key in substitutionMap) {decryptionMap[substitutionMap[key]] = key;
  }
  let decryptedData = "";
  for (let i = 0; i < encryptedData.length; i++) {let char = encryptedData[i];
    if (char.match(/[a-zA-Z]/)) {let substitutionChar = decryptionMap[char.toLowerCase()];
      let decryptedChar = char === char.toLowerCase() ? substitutionChar : substitutionChar.toUpperCase();
      decryptedData += decryptedChar;
    } else {decryptedData += char;}
  }
  return decryptedData;
}

如果您对文章内容有不同认识, 或者疑难,欢送到评论区留言,或者私信我、到咱们的官网找客服号都能够。

如遇本人源码加密后没备份,能够找咱们解决解出复原源码,任何加密都能够

正文完
 0