プロジェクトでは、特定の情報を暗号化するために PHP を使用する必要がある場合があります。つまり、暗号化アルゴリズムによって暗号化された文字列が生成されるため、プログラムは復号化された情報を処理できます。
最も一般的なアプリケーションは、ユーザー ログインと一部の API データ交換シナリオです。
著者は、いくつかの古典的な PHP 暗号化および復号化関数コードを収集して、皆さんと共有します。暗号化と復号化の原理は、一般に、特定の暗号化と復号化アルゴリズムを使用し、そのアルゴリズムにキーを追加し、最終的に暗号化と復号化の結果を取得することです。
1. 非常に強力な認証コード暗号化機能、Discuz! クラシック コード (詳細な説明付き):
コードをコピーします コードは次のとおりです:
関数 authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {
// 動的キーの長さ、同じ平文は動的キーに依存して異なる暗号文を生成します
$ckey_length = 4;
// キー
$key = md5($key ? $key : $GLOBALS['discuz_auth_key']);
// キー a は暗号化と復号化に参加します
$keya = md5(substr($key, 0, 16));
// キー b はデータ整合性の検証に使用されます
$keyb = md5(substr($key, 16, 16));
// キー c は、生成された暗号文を変更するために使用されます
$keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length):
substr(md5(microtime()), -$ckey_length)) : '';
// 計算に関係するキー
$cryptkey = $keya.md5($keya.$keyc);
$key_length = strlen($cryptkey);
// プレーンテキスト。最初の 10 ビットはタイムスタンプの保存に使用され、データの有効性は復号化中に検証され、10 ~ 26 ビットは $keyb (キー b) の保存に使用されます。
//データの整合性は、復号化時にこのキーによって検証されます
// 復号化する場合は、$ckey_length ビットから開始します。これは、暗号文の前の $ckey_length ビットに、正しい復号化を保証するための動的キーが格納されているためです
$string = $operation == 'DECODE' ?base64_decode(substr($string, $ckey_length)) :
sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
$string_length = strlen($string);
$結果 = '';
$box = 範囲(0, 255);
$rndkey = 配列();
// キーブックを生成する
for($i = 0; $i
$rndkey[$i] = ord($cryptkey[$i % $key_length]);
}
// 固定アルゴリズムを使用してキーブックをスクランブルし、ランダム性を高めます。これは非常に複雑に見えますが、実際には暗号文の強度は向上しません。
for($j = $i = 0; $i
$j = ($j + $box[$i] + $rndkey[$i]) % 256;
$tmp = $box[$i];
$box[$i] = $box[$j];
$box[$j] = $tmp;
}
// コアの暗号化と復号化部分
for($a = $j = $i = 0; $i
$a = ($a + 1) % 256;
$j = ($j + $box[$a]) % 256;
$tmp = $box[$a];
$box[$a] = $box[$j];
$box[$j] = $tmp;
// キーブックからキーを取得し、XOR を実行して文字に変換します
$result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
}
If($operation == 'DECODE') {
// データの有効性を検証するには、暗号化されていない平文の形式を参照してください
If((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) &&
substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {
return substr($result, 26);
戻る '';
} その他 {
//動的キーを暗号文に保存します。これが、異なる暗号文を生成した後に同じ平文を復号化できる理由です
// 暗号化された暗号文には特殊文字が含まれている可能性があり、コピー処理中に失われる可能性があるため、base64 エンコードが使用されます
return $keyc.str_replace('=', '',base64_encode($result));
}
}
関数 authcode($string, $operation, $key, $expiry) の $string: 文字列、平文または暗号文; $operation: DECODE は復号化を意味し、その他は暗号化を意味します。 。
使用法:
コードをコピーします コードは次のとおりです:
$str = 'abcdef'
;
$key = 'www.helloweba.com';
echo authcode($str,'ENCODE',$key,0); //暗号化
;
$str = '56f4yER1DI2WTzWMqsfPpS9hwyoJnFP2MpC8SOhRrxO7BOk';
echo authcode($str,'DECODE',$key,0); //復号化
2. 暗号化および復号化関数 encrypt():
コードをコピーします
コードは次のとおりです:function encrypt($string,$operation,$key=''){
$key=md5($key);
$key_length=strlen($key);
$string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string;
$string_length=strlen($string);
$rndkey=$box=配列();
$結果='';
for($i=0;$i
$rndkey[$i]=ord($key[$i%$key_length]);
$box[$i]=$i;
}
for($j=$i=0;$i
$j=($j+$box[$i]+$rndkey[$i])%256;
$tmp=$box[$i];
$box[$i]=$box[$j];
$box[$j]=$tmp;
}
for($a=$j=$i=0;$i
$a=($a+1)%256;
$j=($j+$box[$a])%256;
$tmp=$box[$a];
$box[$a]=$box[$j];
$box[$j]=$tmp;
$result.=chr(ord($string[$i])^($box[($box[$a]+$box[$j])%256]));
}
If($operation=='D'){
If(substr($result,0,8)==substr(md5(substr($result,8).$key),0,8)){
return substr($result,8);
}その他{
戻ります」;
}
}その他{
return str_replace('=','',base64_encode($result));
}
関数 encrypt($string,$operation,$key) では、$string: 暗号化および復号化する必要がある文字列、$operation: 暗号化するか復号化するかを決定します。E は暗号化を意味し、D は復号化を意味します。 。
使用法:
コードをコピーします
コードは次のとおりです:
$str = 'abc';
$key = 'www.helloweba.com';
$token = encrypt($str, 'E', $key);
echo '暗号化:'.encrypt($str, 'E', $key);
echo 'Decrypt:'.encrypt($str, 'D', $key);
http://www.bkjia.com/PHPjc/824703.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/824703.html
技術記事
プロジェクトでは、PHP を使用して特定の情報を暗号化する必要がある場合があります。つまり、暗号化アルゴリズムを通じて暗号化された文字列を生成する必要があります。この暗号化された文字列は、復号化アルゴリズムを通じて処理できます...
。