ホームページ >バックエンド開発 >PHPチュートリアル >PHP における暗号化と復号化の原理と使用法
この記事では、主に PHP の暗号化と復号化のクラスを紹介します。PHP の暗号化と復号化の原理と関連技術を例とともに分析します。必要な方は参考にしてください。
#この記事の例では、PHP の暗号化クラスと復号化クラスについて説明します。具体的な分析は次のとおりです。 このコードは、配列暗号化、暗号文の有効期間、およびさまざまな対称暗号化をサポートしています。パラメータは次のとおりです:* @use ption: :en($ string, $key);* @param String $string 暗号化する必要がある文字列
* @param String $skey キー
* @param int $expiry の有効期限暗号化中に有効な暗号文 (秒単位)。0 は永続的に有効です。
* @return String
/* * -工具库-加密解密码 */ class ption { private static $original = array('=', '+', '/'); private static $later = array('O0O0O', 'o0O0o', 'oo00o'); function __construct() { } private static function md5($skey = '') { $skey = $skey ? $skey : 'ui' ; //uicms::_config('security/authkey'); return md5(substr($skey, 0, 16)); } /** * @use ption::en($string, $key); * @param String $string 需要加密的字串 * @param String $skey 密钥 * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效 * @return String */ static public function en($string = '', $skey = '', $expiry=0) { if( is_array( $string ) ) { $string = json_encode($string); // uicms::json($string, true, 'en'); } $string = str_pad($expiry ? $expiry + TIME : 0, 10, 0).$string; $strArr = str_split(base64_encode($string)); $strCount = count($strArr); $skey = static::md5($skey); foreach (str_split($skey) as $key => $value) { $key < $strCount && $strArr[$key].=$value; } return str_replace(self::$original, self::$later, join('', $strArr)); } /** * @use ption::de($string, $key); * @param String $string 需要解密的字串 * @param String $skey 密钥 * @return String */ static public function de($string = '', $skey = '') { $strArr = str_split(str_replace(self::$later,self::$original,$string),2); $strCount = count($strArr); $skey = static::md5($skey); foreach (str_split($skey) as $key => $value) { $key < $strCount && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0]; } $result = base64_decode(join('', $strArr)); if(substr($result, 0, 10) == 0 || substr($result, 0, 10) - TIME > 0) { return substr($result, 10); } else { return false; } } }2 使用方法は次のとおりです。 :
$str['username'] = 'oschina'; $str['pw'] = '123456'; $str['huoxin'] = '!@#$%^&'; echo "string : " . $str . " <br />"; echo "encode : " . ($enstring = ption::en($str)) . '<br />'; echo "decode : " . ption::de($enstring);
まとめ : 以上がこの記事の全内容となりますが、皆様の学習のお役に立てれば幸いです。
関連する推奨事項:
PHP は、Ajax 呼び出しを通じて Baidu エフェクトに接続します。 Web サイトがインターネットに接続されているかどうかを検出する機能
以上がPHP における暗号化と復号化の原理と使用法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。