XOR算法的原理和實現


XOR算法的原理和實現

XOR算法這種方法的原理

當一個數A和另一個數B進行異或運算會生成另一個數C,如果再將C和B進行異或運算則C又會還原為A。

相對於其他的簡易加密算法,XOR算法的優點如下。

(1)算法簡單,對於高級語言很容易能實現。

(2)速度快,可以在任何時候、任何地方使用。

(3)對任何字符都是有效的,不像有些簡易加密算法,只對西文字符有效,對中文加密后再解密無法還原為原來的字符。

XOR算法實現

上一部分介紹了如何使用XOR運算進行加密/解密的原理,本節將使用其加密用戶的登錄信息。根據上一小節介紹的XOR加密算法的原理,不難寫出以下的加密解密函數。首先列出加密算法。

XOR算法的原理和實現

第4行定義了加密函數myEncrypt(),輸入參數$string為明文,而$key為密鑰;輸出為使用$key作為密鑰並使用XOR加密算法產生的密文。

第6~12行的外層for循環對明文字符串的每一個字符進行循環,而內層的for循環(第8~11行)對明文的每一字符循環與密鑰的每一位做異或運算。其原理已經在上一小節中介紹,不再重述。

同樣,與加密函數類似,可以寫出下面的解密函數。

XOR算法的原理和實現

第4行定義了解密函數myDecrypt(),輸入參數$string為密文,而$key為密鑰;輸出為使用$key作為密鑰並使用XOR解密算法產生的明文。

下面,通過一個應用示例來進一步說明加密函數的功能。

XOR算法的原理和實現

第3行首先定義了一個明文$my_password,然后在第4行定義密鑰$my_key。

第5、6行分別調用加密函數生成密文並輸出;反過來,又在第7、8行將密文解密。

上面示例的運行結果如下。

my_password=chair

my_password_en=RYPXC

my_password_de=chair

在用戶注冊時,用戶需要添寫用戶密碼表單。

除用戶本人之外,其他任何人都無法獲取其密碼信息,包括系統設計者和數據庫管理員。

系統能根據用戶輸入的密碼驗證用戶的合法性。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM