PHP实现的AES加密、解密封装类与用法示例

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了PHP实现的AES加密、解密封装类与用法示例脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了PHP实现的AES加密、解密封装类用法分享给大家供大家参考,具体如下:

PHP;">
key = $key;
    $this->iv = $iv;
  }
  /**
   * 加密数据
   * @param $data
   *
   * @return string
   */
  public function encrypt($data)
  {
    $td = mcrypt_module_open($this->cipher,'',$this->mode,'');
    $key = hash("sha256",$this->key,true);
    $iv = isset($this->iv) ? hash("sha256",$this->iv,true) : $key;
    $data = $this->padding($data);
    mcrypt_generic_init($td,$key,$iv);
    $encryptedData = base64_encode(mcrypt_generic($td,$data));
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    return $encryptedData;
  }
  /**
   * 解密数据
   * @param $data
   *
   * @return bool|string
   */
  public function decrypt($data)
  {
    $td = mcrypt_module_open($this->cipher,true) : $key;
    mcrypt_generic_init($td,$iv);
    $decrypted_data = mdecrypt_generic($td,base64_decode($data));
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    return $this->unPadding($decrypted_data);
  }
  /**
   * 填充数据到分组大小的整数倍
   * @param null $data
   *
   * @return string
   */
  protected function padding($data = null)
  {
    $blockSize = 32; //MCRYPT_RIJNDAEL_256算法的分组大小是32字节
    $pad = $blockSize - (strlen($data) % $blockSize);
    return $data . str_repeat(chr($pad),$pad);
  }
  /**
   * 去掉填充的数据
   * @param null $data
   *
   * @return bool|string
   */
  protected function unPadding($data = null)
  {
    $pad = ord($data[strlen($data) - 1]);
    if ($pad > strlen($data)) {
      return false;
    }
    if (strspn($data,chr($pad),strlen($data) - $pad) != $pad) {
      return false;
    }
    return substr($data,-1 * $pad);
  }
  /**
   * @return mixed
   */
  public function getSecretKey()
  {
    return $this->key;
  }
  /**
   * @param mixed $key
   */
  public function setSecretKey($key)
  {
    $this->key = $key;
  }
  /**
   * @return null
   */
  public function getIv()
  {
    return $this->iv;
  }
  /**
   * @param null $iv
   */
  public function setIv($iv)
  {
    $this->iv = $iv;
  }
}
//使用方法:
$keyStr = 'sq8f77fwhksk';
$aes = new AES($keyStr);
$str = 'www.js-code.com';
$chgstr = $aes->encrypt($str);
echo $chgstr;
echo "
"; $rstr = $aes->decrypt($chgstr); echo $rstr; ?>

脚本宝典总结

以上是脚本宝典为你收集整理的PHP实现的AES加密、解密封装类与用法示例全部内容,希望文章能够帮你解决PHP实现的AES加密、解密封装类与用法示例所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。