zoukankan      html  css  js  c++  java
  • PHP AES128加密解密

    <?php
    /**
     * Class AES
     */
    class AES {
        public static function encrypt($input, $key) {
            $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
            $input = AES::pkcs5_pad($input, $size);
            $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
            $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
            mcrypt_generic_init($td, md5($key), $iv);
            $data = mcrypt_generic($td, $input);
            mcrypt_generic_deinit($td);
            mcrypt_module_close($td);
            $data = base64_encode($data);
    
            return $data;
        }
    
        private static function pkcs5_pad($text, $blocksize) {
            $pad = $blocksize - (strlen($text) % $blocksize);
            return $text . str_repeat(chr($pad), $pad);
        }
    
        private static function hex2bin($hexdata) {
            $bindata = '';
            $length = strlen($hexdata);
            for ($i = 0; $i < $length; $i += 2) {
                $bindata .= chr(hexdec(substr($hexdata, $i, 2)));
            }
            return $bindata;
        }
    
        public static function decrypt($sStr, $sKey) {
            $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
    
            $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
    
            mcrypt_generic_init($td, md5($sKey), $iv);
    
            $decrypted_text = mdecrypt_generic($td, base64_decode($sStr));
            $rt = rtrim($decrypted_text);
    
            mcrypt_generic_deinit($td);
            mcrypt_module_close($td);
            $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
            $rt = AES::pkcs5_pad($rt, $size);
            $dec_s = strlen($rt);
            $padding = ord($rt[$dec_s - 1]);
            $rt = substr($rt, 0, -$padding);
            $rt = rtrim($rt);
            $rt = preg_replace('/(}[^]}{]*)$/', '}', $rt);
            return $rt;
        }
    }
    

      使用方式如下:

    /**
    **中文取消汉字编码
    */
    protected function decodeUnicode($str)
    {
      return preg_replace_callback('/\\u([0-9a-f]{4})/i',
        create_function(
          '$matches',
          'return mb_convert_encoding(pack("H*", $matches[1]), "UTF-8", "UCS-2BE");'
        ),
      $str);
    }

      //加密:

      $data_encrypt = AES::encrypt($this->decodeUnicode(json_encode($data)), 'key');

      //解密:

      $content_decrypt = AES::decrypt($content, 'key');

      $content_decrypt = json_decode($content_decrypt, true);

  • 相关阅读:
    C/C++预定义编译宏
    vi/vim教程
    Shell参数展开
    GNU构建系统和Autotool
    Makefile强制目标(没有命令或依赖的规则)
    C程序的存储空间布局(内存结构)
    linux deamon
    JavaScript高级程序设计——闭包
    PureMVC(JS版)源码解析(三):Observer类
    PureMVC(JS版)源码解析(二):Notification类
  • 原文地址:https://www.cnblogs.com/lovekingly/p/8622663.html
Copyright © 2011-2022 走看看