欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript實現(xiàn)playfair和hill密碼算法

 更新時間:2014年12月07日 14:56:35   投稿:hebedich  
這篇文章主要介紹了javascript實現(xiàn)playfair和hill密碼算法,需要的朋友可以參考下

時至期末,補習(xí)信息安全概論作業(yè)。恰巧遇古典密碼學(xué)算法中的playfair算法和hill算法,用javascript語言實現(xiàn)起來是在有趣,邊查百度邊編碼,順便好好補習(xí)一下javascript基礎(chǔ)。

playfair

Playfair密碼(英文:Playfair cipher 或 Playfair square)是一種替換密碼。依據(jù)一個5*5的正方形組成的密碼表來編寫,表中排列有25個字母。對于英語中的26個字母,去掉最常用的Z,構(gòu)成密碼表。

實現(xiàn)思路:

1,編制密碼表

  密鑰是一個單詞或詞組,密碼表則根據(jù)用戶所給出的密鑰整理而出。若有重復(fù)字母,可將后面重復(fù)的字母去掉?!?/p>

如密鑰crazy dog,可編制成

C
O
H
M
T
R
G
I
N
U
A
B
J
P
V
Y
E
K
Q
W
D
F
L
S
X

復(fù)制代碼 代碼如下:

/*
*    功能:編制密碼表
*
*    參數(shù):密鑰(經(jīng)過去除空格和大寫處理)
*
*    返回:密碼表
*/
function createKey(keychars){
       //字母順序數(shù)組
    var allChars = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y'];
       //變量keychars獲取字母在字母順序表中位置,刪除該字母
    for(var i = 0 ;i<keychars.length;i++){
        var index = allChars.indexOf(keychars[i]);
        if (index > -1) {
            allChars.splice(index, 1);
        }
    }
       //將keychar中的字母插入到字母表中
    for(var i = keychars.length-1;i>=0;i--){
        allChars.unshift(keychars[i]);
    }
        //從第一列將keychars插入至密碼表
    for(var i = 0 ; i<5 ; i++){
        for(var j = 0; j<5 ;j++){
            key[j][i] = allChars[i*5+j];
        }
    }
}   

考慮將keychars插入到密碼表時需要去除重復(fù)字符和Z,設(shè)計算法如下:

復(fù)制代碼 代碼如下:

/*
*    功能:去除字符串中重復(fù)字母
*
*    參數(shù):需要進行處理的字符串
*
*    返回:處理過的字符串
*/
function removeDuplicate(str){
    var result = [],tempStr = "";
    var arr = str.split('');//把字符串分割成數(shù)組
        //arr.sort();//排序
        for(var i = 0; i < arr.length; i++){
            var repeatBack = true;//設(shè)計變量是為確保字符串前部分不存在相同字符,因為以下算法只能確保連在一起相同的字符
            for(var j = 0;j<result.length ;j++){
                if(arr[i] == result[j])
                    repeatBack = false;
            }
            if(arr[i] !== tempStr && repeatBack){
                result.push(arr[i]);
                tempStr = arr[i];
            }else{
                continue;
            }
        }
        return result.join("");//將數(shù)組轉(zhuǎn)換為字符串
}

2,整理明文

  將明文每兩個字母組成一對。如果成對后有兩個相同字母緊挨或最后一個字母是單個的,就插入一個字母X。初期編碼時考慮不周到,強硬地拒絕輸入字母個數(shù)為單數(shù),用戶體驗不佳。

var k = document.getElementById("keychars").value.toUpperCase().replace(/\s/ig,'');
對明文去除空格和轉(zhuǎn)換為大寫處理。

3,編寫密文

明文加密規(guī)則(出自百度):
 
1 )若p1 p2在同一行,對應(yīng)密文c1 c2分別是緊靠p1 p2 右端的字母。其中第一列被看做是最后一列的右方。如,按照前表,ct對應(yīng)oc
2 )若p1 p2在同一列,對應(yīng)密文c1 c2分別是緊靠p1 p2 下方的字母。其中第一行被看做是最后一行的下方。
3 )若p1 p2不在同一行,不在同一列,則c1 c2是由p1 p2確定的矩形的其他兩角的字母(至于橫向替換還是縱向替換要事先約好,或自行嘗試)。如按照前表,wh對應(yīng)tk或kt。
 
如,依照上表,明文where there is life,there is hope.
可先整理為wh er et he re is li fe th er ei sh op ex
然后密文為:kt yg wo ok gy nl hj of cm yg kg lm mb wf
將密文變成大寫,然后幾個字母一組排列。
如5個一組就是KTYGW OOKGY NLHJO FCMYG KGLMM BWF
 
4,解密
將密鑰填寫在一個5*5的矩陣中(去出重復(fù)字母和字母z),矩陣中其它未用到的字母按順序填在矩陣剩余位置中,根據(jù)替換矩陣由密文得到明文。反其道而行。
 
實現(xiàn)效果如圖:

hill

希爾密碼(Hill Password)是運用基本矩陣論原理的替換密碼。依據(jù)一個5*5的正方形組成的密碼表來編寫,表中排列有25個字母。對于英語中的26個字母,去掉最常用的Z,構(gòu)成密碼表。

實現(xiàn)思路:

1,編寫字母表
var chars = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
2,隨機生成密匙

復(fù)制代碼 代碼如下:

/*
*    功能:隨機生成密鑰
*
*    返回:密匙矩陣
*/
function randomCreateKey(){
    //隨機生成0到26的數(shù)字
    for(var i = 0;i<3;i++){
        for(var j = 0;j<3;j++){
            key[i][j] = Math.round(Math.random()*100%26)
        }
    }
}

3,關(guān)鍵性代碼,根據(jù)自動生成的密匙,對明文進行處理:

復(fù)制代碼 代碼如下:

/*
*    功能:hill算法
*
*    參數(shù):長度是3的倍數(shù)的大寫數(shù)組
*   
*    返回:加密后的字符串
*/
function hill(p){
    //大寫字母密文
    var res = "";
        //制定總共需要對字符串經(jīng)行遍歷的次數(shù)
    var round = Math.round(p.length/3);
    //處理
    for(var b = 0;b<round;b++){
        //明文3
            var temp3 ="";
        var tempArr3 = [];
        var sumArr3 = [];
        for(var i = 0;i<3;i++){
            temp3 += p.shift();
            for(var j = 0;j<chars.length;j++){
                if(temp3[i] == chars[j])
                    tempArr3[i] = j;
            }
        }
                //計算
        for(var i =0;i<3;i++){
            for(var j = 0;j<3;j++){
                sumArr3[i] = (tempArr3[j]*key[i][j])%26;
            }
        }
                //獲取字符在字母表中對應(yīng)索引
        for(var i =0;i<3;i++){
            res += chars[sumArr3[i]];
        }
    }
    return res;
};

 實現(xiàn)效果如圖:

以上算法存在不足:

         1,面向過程設(shè)計,耦合度高

         2,過多嵌套循環(huán),算法效率有待優(yōu)化

         3,對于可能出現(xiàn)的情況考慮不周到,例如沒有對用戶輸入非字母字符時進行處理。

總結(jié):

學(xué)了一段時間的信息安全概論這門課,只能對信息安全了解皮毛。信息安全是一門很有趣的科目,平時遇到一些問題盡可能多思考,多動手,多運用。同時也要加強數(shù)學(xué)基礎(chǔ)積累,鞏固js基礎(chǔ),拓寬知識面。這條路任重道遠。

相關(guān)文章

  • JS的document.all函數(shù)使用示例

    JS的document.all函數(shù)使用示例

    JS的document.all函數(shù)在使用中非常的頻繁,下面為大家詳細介紹下具體的使用示例
    2013-12-12
  • 淺談JavaScript數(shù)據(jù)類型

    淺談JavaScript數(shù)據(jù)類型

    本文從javascript的數(shù)據(jù)類型的簡介開始談起,接著講述了javascript的6種數(shù)據(jù)類型,分別為Number、Boolean、String、Null、Undefined和Object,并給出了一個typeof操作符的示例,這里分享給大家。
    2015-03-03
  • IE6瀏覽器下resize事件被執(zhí)行了多次解決方法

    IE6瀏覽器下resize事件被執(zhí)行了多次解決方法

    在IE瀏覽器下,一次resize事件被執(zhí)行了多次,這是IE6和IE7的一個比較廣為認知的問題,這個問題在這兩個版本的瀏覽器中表現(xiàn)有所不同,通常IE6下會比IE7下更為糟糕,接下來將介紹解決方法,需要的朋友可以參考下
    2012-12-12
  • javascript知識點收藏

    javascript知識點收藏

    javascript知識點收藏...
    2007-02-02
  • JavaScript Switch 聲明

    JavaScript Switch 聲明

    JavaScript Switch 聲明...
    2007-04-04
  • javascript函數(shù)作用域?qū)W習(xí)示例(js作用域)

    javascript函數(shù)作用域?qū)W習(xí)示例(js作用域)

    javascript中沒有塊級作用域,取而代之的javascript使用的是函數(shù)作用域,下面使用示例學(xué)習(xí)一下js作用域的使用方法
    2014-01-01
  • 前端變量函數(shù)命名規(guī)則總結(jié)

    前端變量函數(shù)命名規(guī)則總結(jié)

    這篇文章主要為大家介紹了前端變量函數(shù)命名規(guī)則的總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • JavaScript學(xué)習(xí)筆記之Function對象

    JavaScript學(xué)習(xí)筆記之Function對象

    這篇文章主要介紹了JavaScript學(xué)習(xí)筆記之Function對象的相關(guān)資料,需要的朋友可以參考下
    2015-01-01
  • 淺談Javascript常用正則表達式應(yīng)用

    淺談Javascript常用正則表達式應(yīng)用

    這篇文章主要介紹了Javascript常用正則表達式應(yīng)用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • appendChild() 或 insertBefore()使用與區(qū)別介紹

    appendChild() 或 insertBefore()使用與區(qū)別介紹

    appendChild() 方法在節(jié)點的子節(jié)點列表末添加新的子節(jié)點。insertBefore() 方法在節(jié)點的子節(jié)點列表任意位置插入新的節(jié)點,下面為大家介紹下具體的使用,感興趣的朋友不要錯過
    2013-10-10

最新評論