凯撒密码只正确获得第一价值

时间:2018-12-13 19:14:07

标签: javascript encryption fromcharcode

我的凯撒密码仅适用于第一个字母,我曾尝试过使用嵌套的for循环来移动变量,但似乎无法弄清楚。 FREE PIZZA应该翻译成SERR CVMMN,但这给了我很多奇怪的符号和小写的翻译。

function rot13(str) { // LBH QVQ VG!
let x = str;
let y = [];
let n = ''
for(let i = 0; i < x.length; i++) {

    y.push(x.charCodeAt(i) + 13)

    console.log(x.charCodeAt(i))

}
console.log(y)

for(let j = 0; j < y.length; j++){
  console.log(y[j])
 n += String.fromCharCode(y[j])
}
console.log(n)

  return n;
}

1 个答案:

答案 0 :(得分:3)

使用charCode时,将获得字符的unicode值,对于大写英文字母,其范围为65–90。添加13时,将获得字符“ NOPQRSTUVWXYZ [] ^ _`abcdefg”的unicode值。

您需要找到一种方法,使英文字符仅映射到13步远的英文字符,并进行环绕,以便以后的字符映射到较早的字符(以便Z映射到M)。

如果您使用unicode值而不是使用自己的字母(例如下面的代码段)删除,这可能更容易实现

function rot13(str) {
  let x = str.toUpperCase();
  let y = [];
  let n = "";
  let alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
  for (let i = 0; i < x.length; i++) {
    if (alphabet.indexOf(x.charAt(i)) > -1) {
      n += alphabet.charAt((alphabet.indexOf(x.charAt(i)) + 13) % 26);
    } else {
      n += x.charAt(i);
    }
  }
  return n;
}

console.log(rot13("FREE PIZZA"));

一种更简单的方法是只使用查找表(完全避免使用数学方法):

function rot13(str) {
  let x = str.toUpperCase().split("");
  let table = {
    A: "N", B: "O", C: "P", D: "Q",
    E: "R", F: "S", G: "T", H: "U",
    I: "V", J: "W", K: "X", L: "Y",
    M: "Z", N: "A", O: "B", P: "C",
    Q: "D", R: "E", S: "F", T: "G",
    U: "H", V: "I", W: "J", X: "K",
    Y: "L", Z: "M"
  };
  for (let i = 0; i < x.length; i++) {
    if (table[x[i]]) {
      x[i] = table[x[i]];
    }
  }
  return x.join("");
}

console.log(rot13("FREE PIZZA"));