ホームページ  >  記事  >  バックエンド開発  >  PHP で情報の暗号化と復号化を実装する方法

PHP で情報の暗号化と復号化を実装する方法

WBOY
WBOYオリジナル
2023-06-18 10:10:392853ブラウズ

情報技術の急速な発展に伴い、情報の暗号化と復号化は、今日のデジタル情報を保護する重要な手段の 1 つになりました。 Web 開発の分野で広く使用されているプログラミング言語として、情報を暗号化および復号化する PHP の方法も非常に重要になっています。

この記事では、PHP で情報の暗号化と復号化を実装する方法をいくつか紹介します。

1. PHP 独自の暗号化関数を使用する

PHP では、一連の組み込み暗号化関数を使用してデータを暗号化および復号化できます。これらの関数には、md5()、sha1()、base64_encode()、base64_decode() などが含まれます。

最初に、デモンストレーション用にbase64_encode()関数とbase64_decode()関数を選択します。データを A ~ Z、a ~ z、0 ~ 9、、、/ の文字で構成される文字列のセットに変換し、復号化後に元のデータを復元できます。

具体的な実装コードは次のとおりです。

//加密函数
function encrypt($data){
    $data = base64_encode($data);
    return $data;
}

//解密函数
function decrypt($data){
    $data = base64_decode($data);
    return $data;
}

これら 2 つの関数を通じて、データの単純な暗号化と復号化を実現できます。ただし、この方法は簡単にブルートフォース攻撃を受ける可能性があるため、あまり安全ではないことに注意してください。

2. 対称暗号化アルゴリズムを使用する

対称暗号化アルゴリズムは、データの暗号化と復号化に同じキーを使用するアルゴリズムです。一般的な対称暗号化アルゴリズムには、DES、AES などが含まれます。

PHP では、mcrypt ライブラリまたは openssl 拡張機能を使用して対称暗号化アルゴリズムを実装できます。

AES アルゴリズムを例として、対称暗号化アルゴリズムの実装方法を示します。具体的な実装コードは以下の通りです。

$key = '1234567890123456'; //密钥
$plaintext = 'Hello, world!'; //原始明文数据

//加密
$ciphertext = openssl_encrypt($plaintext, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, '1234567890123456');
$ciphertext = base64_encode($ciphertext);

//解密
$ciphertext = base64_decode($ciphertext);
$plaintext = openssl_decrypt($ciphertext, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, '1234567890123456');

このうち、$keyがキー、$plaintextが元の平文データです。暗号化には openssl_encrypt() 関数が使用され、復号化には openssl_decrypt() 関数が使用されます。

暗号化アルゴリズムの選択は実際の状況に基づいて行う必要があることに注意してください。より安全な暗号化方法を検討する場合は、AES-256 アルゴリズムを選択できますが、暗号化速度は比較的遅くなります。

3. 非対称暗号化アルゴリズムを使用する

非対称暗号化アルゴリズムは、キーのペア (公開キーと秘密キー) を使用してデータの暗号化と復号化を行うアルゴリズムです。アルゴリズムはRSAです。

PHP では、openssl 拡張機能を使用して非対称暗号化アルゴリズムを実装できます。

RSA アルゴリズムを例として、非対称暗号化アルゴリズムの実装方法を示します。具体的な実装コードは以下の通りです。

$private_key = <<<EOD
-----BEGIN RSA PRIVATE KEY-----
MIICXAIBAAKBgQC7C1DJoA4vf6Z+/gwTt3eOjQqi7odXbVf/eKeTX2YVi2wS+Z02
Jbcm8+pkuGZDNxXgO89qr13ytGWUhcSy2t/hRMmLjAdEIiCU8a9VcdDsk1Bgz4Ir
qKLj84XdT3pc5N9yMSsEItvqn31ro7/5nDdzRJAsWH6xd220EaJLZL7/hwIDAQAB
AoGBAIJc3cZhytX5jni/jdDa7+keAwDTbLsPAx1pyJvZbIZ26v8f8cxVgCD1yJ0+
Fm6fi/BTcCfi5UOD6ClIdYxQ9ZsHkhDkU+z8r114kguNziHkrm2kR/ijXmYdNDaU
Y9jNtRjvMHOQWfj+ym9p2jKJd/wYG1TodY5AVMJeSLvjo/7RAkEA/6je8XnhVADo
xMGs/eJ80AYEVo11+6PjxVVqivJ0O0l8DNd+4ih+U2ohjvQEjBpfcUGWx+cpxhR8
iE5TgrPXswJBANg/xhNhMNqL4DsXdc0y37n68QAVR/+SNYkipUZqHSIqe6LH4db/
H09kWeZJQ4ArtiIwgl5Q5dgngnAubdVreRUCQDXN287lEns+hIn7GUYWCO5V4fND
WbM8K02UaO+qutglLrbzIlLa6+IjYb+7p8adR/K66QiLJe6UdMze3/Nlzi0CQQCV
Xa5m6m1Q7lfALG53u0dvpVx3JmIEPZvfYh8onMyODFfF4PPFNZwgIjlbSRVTFxJ1
hW2PWF1EBbJ2vEI7tWnBAkEAt0LnrmfkApmwhPiEKzjvezUnTeqWcZaImp7uZ8V7
av2Q43WTXNQeKAzI4ItZHvEKtN0Xrnvah7NiW7K7ZQA25w==
-----END RSA PRIVATE KEY-----
EOD;

$public_key = <<<EOD
-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC7C1DJoA4vf6Z+/gwTt3eOjQqi
7odXbVf/eKeTX2YVi2wS+Z02Jbcm8+pkuGZDNxXgO89qr13ytGWUhcSy2t/hRMmL
jAdEIiCU8a9VcdDsk1Bgz4IrqKLj84XdT3pc5N9yMSsEItvqn31ro7/5nDdzRJAs
WH6xd220EaJLZL7/hwIDAQAB
-----END PUBLIC KEY-----
EOD;

$plaintext = 'Hello, world!';

//私钥加密
openssl_private_encrypt($plaintext, $ciphertext, $private_key);
$ciphertext = base64_encode($ciphertext);

//公钥解密
$ciphertext = base64_decode($ciphertext);
openssl_public_decrypt($ciphertext, $plaintext, $public_key);

このうち、$private_keyは秘密鍵、$public_keyは公開鍵、$plaintextは元の平文データです。暗号化には openssl_private_encrypt() 関数が使用され、復号化には openssl_public_decrypt() 関数が使用されます。

RSA アルゴリズムは暗号化速度が遅いため、大量のデータの暗号化には適していません。実際のアプリケーションでは、対称暗号化アルゴリズムと非対称暗号化アルゴリズムを組み合わせて使用​​できます。最初に対称暗号化アルゴリズムを使用してデータを暗号化し、次に非対称暗号化アルゴリズムを使用して対称暗号化アルゴリズムで使用されるキーを暗号化します。

要約すると、上記は PHP で情報の暗号化と復号化を実装するためのいくつかの方法です。実際のアプリケーションでは、実際のニーズとセキュリティに基づいてどの暗号化方式を選択するかを検討する必要があります。

以上がPHP で情報の暗号化と復号化を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。