PHP における暗号化と復号化の原理と使用法

墨辰丷
リリース: 2023-03-31 15:08:02
オリジナル
2991 人が閲覧しました

この記事では、主に PHP の暗号化と復号化のクラスを紹介します。PHP の暗号化と復号化の原理と関連技術を例とともに分析します。必要な方は参考にしてください。

#この記事の例では、PHP の暗号化クラスと復号化クラスについて説明します。具体的な分析は次のとおりです。

このコードは、配列暗号化、暗号文の有効期間、およびさまざまな対称暗号化をサポートしています。

パラメータは次のとおりです:

* @use ption: :en($ string, $key);

* @param String $string 暗号化する必要がある文字列
* @param String $skey キー
* @param int $expiry の有効期限暗号化中に有効な暗号文 (秒単位)。0 は永続的に有効です。
* @return String

1。php コードは次のとおりです。

/*
 * -工具库-加密解密码
*/
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(&#39;&#39;, $strArr));
 }
 /**
 * @use ption::de($string, $key);
 * @param String $string 需要解密的字串
 * @param String $skey 密钥
 * @return String
 */
 static public function de($string = &#39;&#39;, $skey = &#39;&#39;)
 {   
  $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(&#39;&#39;, $strArr));
  if(substr($result, 0, 10) == 0 || substr($result, 0, 10) - TIME > 0)
  {
   return substr($result, 10);
  }
  else
  {
   return false;
  }   
 }  
}
ログイン後にコピー

2 使用方法は次のとおりです。 :

$str[&#39;username&#39;] = &#39;oschina&#39;;
$str[&#39;pw&#39;] = &#39;123456&#39;;
$str[&#39;huoxin&#39;] = &#39;!@#$%^&&#39;;
echo "string : " . $str . " <br />";
echo "encode : " . ($enstring = ption::en($str)) . &#39;<br />&#39;;
echo "decode : " . ption::de($enstring);
ログイン後にコピー

まとめ : 以上がこの記事の全内容となりますが、皆様の学習のお役に立てれば幸いです。

関連する推奨事項:

PHP フローの基本知識

PHP は、Ajax 呼び出しを通じて Baidu エフェクトに接続します。 Web サイトがインターネットに接続されているかどうかを検出する機能

PHP の三項演算子

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

関連ラベル:
php
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!