ホームページ  >  記事  >  バックエンド開発  >  2 つの古典的な PHP 暗号化および復号化関数を共有する

2 つの古典的な PHP 暗号化および復号化関数を共有する

WBOY
WBOYオリジナル
2016-07-25 08:43:00797ブラウズ

この記事では主に、さらに 2 つの古典的な PHP 暗号化関数と復号化関数の共有について紹介します。1 つは Discuz! の authcode 暗号化関数 (詳細な分解付き)、もう 1 つは encrypt() 関数で、どちらも比較的古典的な Friends です。必要な場合はそれを参照してください

プロジェクトでは、場合によっては、PHP を使用して特定の情報を暗号化する必要があります。つまり、プログラムが復号化された情報を処理できるように、暗号化アルゴリズムを通じて暗号化された文字列を生成する必要があります。
最も一般的なアプリケーションは、ユーザー ログインと一部の API データ交換シナリオにあります。

著者は、いくつかの古典的な PHP 暗号化および復号化関数コードを収集して、皆さんと共有します。暗号化と復号化の原理は、一般に、特定の暗号化と復号化アルゴリズムを使用し、そのアルゴリズムにキーを追加し、最終的に暗号化と復号化の結果を取得することです。
1. 非常に強力な認証コード暗号化関数、Discuz! クラシック コード (詳細な説明付き):
    function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {
  1. // 動的キーの長さ。同じ平文は動的キーに応じて異なる暗号文を生成します
  2. $ckey_length = 4 // キー
  3. $key = md5($key ? $key : $ GLOBALS[ 'discuz_auth_key']);
  4. // キー a は暗号化と復号化に参加します
  5. $keya = md5(substr($key, 0, 16)) // キー b はデータの整合性のために使用されますverify
  6. $keyb = md5(substr($key, 16, 16));
  7. // キー c は生成された暗号文を変更するために使用されます
  8. $keyc = $ckey_length ? ($operation == ' DECODE' ? substr ($string, 0, $ckey_length):
  9. substr(md5(microtime()), -$ckey_length)) : '';
  10. // 操作に含まれるキー
  11. $cryptkey = $keya .md5( $keya.$keyc);
  12. $key_length = strlen($cryptkey); // プレーンテキスト、最初の 10 ビットはタイムスタンプの保存に使用され、データの有効性は復号化時に検証されます。 $keyb (key b),
  13. //このキーは、復号化するときにデータの整合性を検証するために使用されます
  14. // 復号化する場合は、$ckey_length ビットから開始します。暗号文には、正しい復号化を保証するための動的な秘密鍵が保存されます
  15. $string = $operation == 'DECODE' ?base64_decode(substr($string, $ckey_length)) :
  16. sprintf('%010d', $expiry ? $有効期限 + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
  17. $result = ''; box = range(0, 255);
  18. $rndkey = array();
  19. // キーブックを生成します
  20. for($i = 0; $i
  21. $rndkey[ $i] = ord ($cryptkey[$i % $key_length]);
  22. }
  23. // 固定アルゴリズムを使用してキーブックをスクランブルし、ランダム性を高めます。これは非常に複雑に見えますが、実際には、暗号文の強度
  24. for($j = $i = 0; $i
  25. $j = ($j + $box[$i] + $rndkey[$i]) % 256;
  26. $ tmp = $box[$i];
  27. $box[$j] = $tmp;暗号化と復号化の部分
  28. for($a = $j = $i = 0; $i < $string_length; $i++) {
  29. $a = ($a + 1) % 256;
  30. $j = ( $j + $box[$a]) % 256;
  31. $tmp = $box[$a]
  32. $box[$a] = $box[$j]; $tmp;
  33. / / キーブックからキーを取得し、XOR を実行して文字に変換します
  34. $result .= chr(ord($string[$i]) ^ ($box[($box[ $a] + $box[ $j]) % 256]));
  35. }
  36. if($operation == 'DECODE') {
  37. // データの有効性を確認するには、暗号化されていない平文の形式を参照してください
  38. if((substr($ result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) &&
  39. substr($result, 10, 16) == substr (md5(substr($result , 26).$keyb), 0, 16)) {
  40. return substr($result, 26);
  41. } else {
  42. return ''; {
  43. // 動的を変更します キーは暗号文に保存されているため、異なる暗号文を生成した後に同じ平文を復号化できます
  44. // 暗号化された暗号文には特殊文字が含まれている可能性があり、コピー プロセス中に失われる可能性があるためです、base64 でエンコードされています
  45. return $keyc.str_replace('=', '',base64_encode($result));
  46. }
  47. }
  48. コードをコピーします

  49. 関数 authcode($string, $operation, $key, $expiry) の $string: 文字列、平文または暗号文; $operation: DECODE は暗号化を意味し、$key: 暗号化キーを意味します。 。

    使用法:
    1. $str = 'abcdef';
    2. $key = 'www.helloweba.com';
    3. echo authcode($str,'ENCODE',$key,0); //暗号化
    4. $str = '56f4yER1DI2WTzWMqsfPpS9hwyoJnFP2MpC8SOhRrxO7BOk';
    5. echo authcode($str,'DECODE',$key,0) //コードをコピーします
    2. 暗号化および復号化関数 encrypt():

    function encrypt($string,$operation,$key=''){
    1. $key=md5($key); $ key_length=strlen($key);
    2. $string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string; string_length =strlen($string);
    3. $rndkey=$box=array();
    4. for($i=0;$i<=255;$i++){
    5. $ rndkey [$i]=ord($key[$i%$key_length]);
    6. $box[$i]=$i }
    7. for($j=$i=0;$i
    8. $j=($j+$box[$i]+$rndkey[$i])%256;
    9. $tmp=$box[$i]; = $box[$j];
    10. $box[$j]=$tmp;
    11. for($a=$j=$i=0;$i<$string_length;$i++){
    12. $ a=($a+1)%256;
    13. $j=($j+$box[$a])%256;
    14. $tmp=$box[$a]; = $box[$j];
    15. $box[$j]=$tmp;
    16. $result.=chr(ord($string[$i])^($box[($box[$a]+ $ box[$j])%256]));
    17. }
    18. if($operation=='D'){
    19. if(substr($result,0,8)==substr(md5(substr( $ result,8).$key),0,8)){
    20. return substr($result,8);
    21. }else{
    22. }
    23. }else{
    24. return str_replace ( '=','',base64_encode($result));
    25. }
    26. }
    27. コードをコピーします
    28. 関数 encrypt($string,$operation,$key) では、$string: 暗号化および復号化する必要がある文字列、$operation: 暗号化するか復号化するかを決定します。E は暗号化を意味し、D は復号化を意味します。 。
    29. 使用法:
    30. $str = 'abc';
    31. $key = 'www.helloweba.com';
    32. $token = encrypt($str, 'E', $key);
    33. echo '暗号化:'。 encrypt($str, 'E', $key);
    34. echo 'Decrypt:'.encrypt($str, 'D', $key);
    35. コードをコピーします。
    暗号化と復号化、PHP


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