ホームページ >ウェブフロントエンド >フロントエンドQ&A >JavaScript 可逆暗号化アルゴリズムの簡単な実装 - xor 排他的 OR 演算
電子商取引の台頭により、ネットワーク セキュリティへの注目がますます高まっています。データがネットワーク上で送信される場合、多くの場合、データの機密性を保護するためにデータを暗号化する必要があります。 JavaScript は非常に重要なネットワーク プログラミング言語として使用されており、データ送信の仲介者として機密性が非常に重要です。この記事では、JavaScript の可逆暗号化アルゴリズムの 1 つである XOR 演算を紹介します。
XOR演算は論理演算であり、出力結果は2つの入力値を比較し、2つの値が異なる場合は1を、異なる場合は0を出力します。 XOR 演算の記号は ^ です。
JavaScript では、XOR 演算を使用して単純な暗号化と復号化を実装できます。暗号化に使用されるキーのセットと暗号化される平文値に対してビットごとの XOR 演算を実行し、その結果が暗号文になります。同様に、元の平文データは、キーと暗号文に対してビットごとの XOR 演算を実行することで取得できます。
次は JavaScript XOR 暗号化のアルゴリズム実装です:
function xor_encrypt(data, key) { var result = ''; for(var i = 0; i < data.length; i++) { result += String.fromCharCode(data[i] ^ key.charCodeAt(i % key.length)); } return result; } function xor_decrypt(data, key) { var result = ''; for(var i = 0; i < data.length; i++) { result += String.fromCharCode(data[i] ^ key.charCodeAt(i % key.length)); } return result; }
上記のコードはシンプルで理解しやすいです。まず、データは受信した平文とキー、および平文を通じて暗号化されます。とキーはビットごとに暗号化され、XOR 演算の結果は結果文字列に保存されます。復号化操作も同様で、暗号文とキーがビット単位で XOR 演算され、結果が結果文字列に保存されます。
上記のアルゴリズムの実装をよりよく理解するために、簡単なサンプル プログラムを実装してみましょう:
var data = 'Hello World!'; var key = 'password'; var encrypted = xor_encrypt(data, key); var decrypted = xor_decrypt(encrypted, key); console.log('明文:' + data); console.log('密钥:' + key); console.log('密文:' + encrypted); console.log('解密后的明文:' + decrypted);
上記のプログラムを実行すると、次の出力が得られます:
明文:Hello World! 密钥:password 密文:jVyooRMa/^a_ 解密后的明文:Hello World!
以上により、サンプルプログラムでは、XOR演算により暗号化されたデータが文字化けしていることがわかりますが、復号演算を行うと元の平文データが得られます。これにより、シンプルで信頼性の高い暗号化アルゴリズムが実現されます。
もちろん、XOR 演算を使用して実装された暗号化および復号化アルゴリズムは完全に安全ではなく、一部の単純なデータ暗号化シナリオにのみ適しています。より高度なセキュリティ要件が必要なシナリオがある場合は、より複雑な暗号化アルゴリズムを使用する必要があります。 。
つまり、JavaScript の XOR 演算は、暗号化と復号化演算を簡単に実装できるシンプルで効果的な暗号化アルゴリズムですが、将来的に解読されないという保証はありません。実際のシナリオでは、特定の状況に基づいて選択と適用を行う必要があります。
以上がJavaScript 可逆暗号化アルゴリズムの簡単な実装 - xor 排他的 OR 演算の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。