首頁 >web前端 >js教程 >JavaScript實作維吉尼亞(Vigenere)密碼演算法實例_javascript技巧

JavaScript實作維吉尼亞(Vigenere)密碼演算法實例_javascript技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-05-16 17:13:112356瀏覽

傳統加密技術對於當今的網路安全發揮不了大作用,但每一本講述密碼學的書的開頭都會率先介紹它們,因為它們是密碼學的基礎,是密碼學的歷史。幾乎每一本密碼學的書在講述Vigenere密碼的章節都會有這麼一個《Vigenere代換錶》用戶講解Vigenere密碼機制:

JavaScript實作維吉尼亞(Vigenere)密碼演算法實例_javascript技巧

加密過程很簡單,就是給定密鑰字母x和明文字母y,密文字母是位於x行和y列的那個字母。這樣就決定了加密一條訊息需要與訊息一樣長的密鑰字串,通常,密鑰字串是密鑰詞的重複。
以《密碼編碼學與網路安全-原理與實務》中的例子來作為本文的例子。例如密鑰詞是deceptive,訊息是“we are discovered save yourself”,那麼加密過程如下:

複製程式碼 程式碼如下:

deceptivedeceptivedeceptive(>

deceptivedeceptivedeceptive(Yourt)訊息)
ZICVTWQNGRZGVTWAVZHCQYGLMGJ(密文)

密文中的第一個字母「Z」是怎麼得來的?從Vigenere代換表中,以密鑰字串中的「d」為行,訊息中的「w」為列的那個字母就是「Z」了。


使用查表的方式多加密幾次就能很輕易地總結出規律:將A~Z以0~25編號,那麼加密過程就是,在代換表的第一行中找到消息字母,如「w”,然後向後移動d(即3)次,所得的字母就是密文了。如果數到末位,那麼下一次移位就從頭(即A)繼續。 也就是說,可以將A~Z看成一個環,加密過程就是找定訊息字母後,將指標往環的某個特定方向移位,次數就是密鑰字母所代表的數字。這其實是一個模26的過程。
擴充一下,以上加密僅能對26個字母進行加密,而且不能區分大小寫。但其實英文除了字母外,還有標點符號,還有空格。如果考慮到大部分英文字符,那麼Vigenere代換錶將比較大,而且有點浪費空間的嫌疑。如果假設能被加密的字元有N個,如果把這N個字元建成一個環,那麼加密過程就是模N的過程,即,C(i)=(K(i) P(i))modN,其中K、C、P分別代表的是金鑰空間、密文空間、訊息(明文)空間。

網路上有人用C實作了這個加密演算法,幾乎都是用查代換表的方法。雖然可以程式產生代換表,但所產生的代換表太有規律了。以下我用Javascript實作了一次,使用的是模的方法,感覺靈活度更大,佔用的空間肯定也更小(時間效率尚未估計)

程式碼如下:

var Vigenere = {
    _strCpr: 'abcdefghijklmnopqrstuvwxyz_12345 67890.ABCDEFGHIJKLMNOPQRSTUVWXYZ',//可以將此字符串的順序打亂點,或者添加更多字符
    _strKey: function(strK,str ){//產生金鑰字串,strK為金鑰,str為明文或密文
        var lenStrK = strK.length;
      ){//如果密鑰長度與str不同,則需要產生密鑰字串
            if(lenStrK                 while(lenStrK                        lenStrK = 2 * lenStrK;
              等於str長度
            strK = strK.substring(0,lenStr);//將金鑰字串截取為與str等長的字串
   }
}

Vigenere.lenCpr = Vigenere._strCpr.length;

Vigenere.Encrypt = function(K,P){//加密演算法,K為金鑰,P為明文
    K = Vigenere._strKey(K,P);    var lenK = K.lengthK = K.length ;

    var rlt = '';

    var loop = 0;

    for(loop=0; loop        if(iP==-1) return '此演算法暫時無法對字元:' P.charAt(loop) '進行加密';
      charAt(loop));
        if(iK==-1) return '金鑰包含非法字元:' K.charAt(loop);
        var i = (iP iKlen) %gene       var i = (iP iKlen) %gene 🎜>        rlt = rlt Vigenere._strCpr.charAt(i);
    }
    return rlt;   
};
};Vigenere.DisEncrypt = function(K,C){
    K = Vigenere._strKey(K,C);
    var lenK = K.length;
 var loop = 0;
    for(loop=0; loop        var iK = Vigenere._strCpr.indexO==(K.charAt(loop));        var iC = Vigenere._strCpr.indexOf charAt(loop));

            rlt = Vigenere._strCpr.charAt(iC Vigenere.lenCpr - iK);
           rlt = Vigenere._strCpr.charAt(iC - iK);
        }
}
    return rlt;
};


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn