php aes加密解密类(兼容php5、php7)
admin
2023-06-12 19:22:23
0
]>
 */
class aes{
    // 加密方式:1、mcrypt;2、openssl 默认1
    private $type;
    // cast-128  gost  rijndael-128  twofish  cast-256  loki97  rijndael-192  saferplus  wake  blowfish-compat  des  rijndael-256  serpent  xtea  blowfish  enigma  rc2  tripledes  arcfour
    // AES-128-CBC  AES-128-CFB  AES-128-CFB1  AES-128-CFB8  AES-128-CTR  AES-128-ECB  AES-128-OFB  AES-128-XTS  AES-192-CBC  AES-192-CFB  AES-192-CFB1  AES-192-CFB8  AES-192-CTR  AES-192-ECB  AES-192-OFB  AES-256-CBC  AES-256-CFB  AES-256-CFB1  AES-256-CFB8  AES-256-CTR  AES-256-ECB  AES-256-OFB  AES-256-XTS  BF-CBC  BF-CFB  BF-ECB  BF-OFB  CAMELLIA-128-CBC  CAMELLIA-128-CFB  CAMELLIA-128-CFB1  CAMELLIA-128-CFB8  CAMELLIA-128-ECB  CAMELLIA-128-OFB  CAMELLIA-192-CBC  CAMELLIA-192-CFB  CAMELLIA-192-CFB1  CAMELLIA-192-CFB8  CAMELLIA-192-ECB  CAMELLIA-192-OFB  CAMELLIA-256-CBC  CAMELLIA-256-CFB  CAMELLIA-256-CFB1  CAMELLIA-256-CFB8  CAMELLIA-256-ECB  CAMELLIA-256-OFB  CAST5-CBC  CAST5-CFB  CAST5-ECB  CAST5-OFB  DES-CBC  DES-CFB  DES-CFB1  DES-CFB8  DES-ECB  DES-EDE  DES-EDE-CBC  DES-EDE-CFB  DES-EDE-OFB  DES-EDE3  DES-EDE3-CBC  DES-EDE3-CFB  DES-EDE3-CFB1  DES-EDE3-CFB8  DES-EDE3-OFB  DES-OFB  DESX-CBC  GOST 28147-89  IDEA-CBC  IDEA-CFB  IDEA-ECB  IDEA-OFB  RC2-40-CBC  RC2-64-CBC  RC2-CBC  RC2-CFB  RC2-ECB  RC2-OFB  RC4  RC4-40  RC4-HMAC-MD5  SEED-CBC  SEED-CFB  SEED-ECB  SEED-OFB  aes-128-cbc  aes-128-ccm  aes-128-cfb  aes-128-cfb1  aes-128-cfb8  aes-128-ctr  aes-128-ecb  aes-128-gcm  aes-128-ofb  aes-128-xts  aes-192-cbc  aes-192-ccm  aes-192-cfb  aes-192-cfb1  aes-192-cfb8  aes-192-ctr  aes-192-ecb  aes-192-gcm  aes-192-ofb  aes-256-cbc  aes-256-ccm  aes-256-cfb  aes-256-cfb1  aes-256-cfb8  aes-256-ctr  aes-256-ecb  aes-256-gcm  aes-256-ofb  aes-256-xts  bf-cbc  bf-cfb  bf-ecb  bf-ofb  camellia-128-cbc  camellia-128-cfb  camellia-128-cfb1  camellia-128-cfb8  camellia-128-ecb  camellia-128-ofb  camellia-192-cbc  camellia-192-cfb  camellia-192-cfb1  camellia-192-cfb8  camellia-192-ecb  camellia-192-ofb  camellia-256-cbc  camellia-256-cfb  camellia-256-cfb1  camellia-256-cfb8  camellia-256-ecb  camellia-256-ofb  cast5-cbc  cast5-cfb  cast5-ecb  cast5-ofb  des-cbc  des-cfb  des-cfb1  des-cfb8  des-ecb  des-ede  des-ede-cbc  des-ede-cfb  des-ede-ofb  des-ede3  des-ede3-cbc  des-ede3-cfb  des-ede3-cfb1  des-ede3-cfb8  des-ede3-ofb  des-ofb  desx-cbc  gost89  gost89-cnt  id-aes128-CCM  id-aes128-GCM  id-aes128-wrap  id-aes192-CCM  id-aes192-GCM  id-aes192-wrap  id-aes256-CCM  id-aes256-GCM  id-aes256-wrap  id-smime-alg-CMS3DESwrap  idea-cbc  idea-cfb  idea-ecb  idea-ofb  rc2-40-cbc  rc2-64-cbc  rc2-cbc  rc2-cfb  rc2-ecb  rc2-ofb  rc4  rc4-40  rc4-hmac-md5  seed-cbc  seed-cfb  seed-ecb  seed-ofb
    private $cipher = 'seed-ofb';
    // cbc  cfb  ctr  ecb  ncfb  nofb  ofb  stream  
    private $mode = 'stream';
    private $iv;
    // MCRYPT_RAND  MCRYPT_DEV_RANDOM  MCRYPT_DEV_URANDOM
    private $source = MCRYPT_RAND;
    private $key;
    private $data;
    /*
     构造函数
     @param key 密钥
     @param type 加密类型:1、mcrypt;2、openssl
     */
    public function __construct($key,$type = 1){
        $this->key = $key;
        $this->type = $type;
    }
    private function getiv(){
        $cipher = $this->cipher;
        $mode = $this->mode;
        $source = $this->source;
        $size = mcrypt_get_iv_size($cipher,$mode);
        $iv = mcrypt_create_iv($size,$source);
        return $iv;
    }
    public function encrypt($data){
        $type = $this->type;
        $cipher = $this->cipher;
        $mode = $this->mode;
        $key = $this->key;
        if($type == 1){
            $iv = $this->getiv();
            $td = mcrypt_module_open($cipher, "", $mode, "");
            mcrypt_generic_init($td, $key, $iv);
            $encrypted = mcrypt_generic($td, $data);
            mcrypt_generic_deinit($td);
            mcrypt_module_close($td);
            $ret = base64_encode($encrypted);
        }else{
            $encryption_key = base64_decode($key);
            $len = openssl_cipher_iv_length($cipher);
            $iv = openssl_random_pseudo_bytes($len);
            $encrypted = openssl_encrypt($data, $cipher, $encryption_key, 0, $iv);
            $ret = base64_encode($encrypted . '::' . $iv);
        }
        return $ret;
    }
    public function decrypt($data){
        $type = $this->type;
        $cipher = $this->cipher;
        $mode = $this->mode;
        $key = $this->key;
        if($type == 1){
            $iv = $this->getiv();
            $td = mcrypt_module_open($cipher,"",$mode,"");
            mcrypt_generic_init($td, $key, $iv);
            $decode = base64_decode($data);
            $dencrypted = mdecrypt_generic($td, $decode);
            mcrypt_generic_deinit($td);
            mcrypt_module_close($td);
            $ret = $dencrypted;
        }else{
            $encryption_key = base64_decode($key);
            $arr = explode('::', base64_decode($data));
            $encrypted_data = $arr[0];
            $iv = $arr[1];
            $ret = openssl_decrypt($encrypted_data, $cipher, $encryption_key, 0, $iv);
        }
        return $ret;
    }
}
// $key = 'abcdefg';
// $data = '你好 world';
// $aes = new aes($key,2);
// $encode = $aes->encrypt($data);
// echo $encode.PHP_EOL;
// $decode = $aes->decrypt($encode);
// echo $decode.PHP_EOL;

相关内容

热门资讯

半岛电视台:美伊就资产解冻问题... 新华社多哈5月25日电(记者汪强)卡塔尔半岛电视台25日报道,一名了解伊朗高级代表团在多哈会谈情况的...
多地积极探索算电协同创新模式 本报记者 李万晨曦 近日,南方电网广西电网公司联合中国移动广西公司开展了首次算电协同响应实景测试,成...
乘舟向天宫 逐梦揽星河——神舟... 乘舟向天宫  逐梦揽星河 ——神舟二十三号载人飞行任务乘组出征侧记 ■杨子凡 解放军报记者 赵 倩 ...
基恩士相机无图像维修服务商梳理... 导语:在工业自动化设备运维中,基恩士相机作为视觉检测的核心部件,其稳定性直接影响生产线效率。针对无图...
新型3D打印技术问世 机构高频... 新型3D打印技术问世机构高频调研3只概念股 人民财讯5月25日电,2026年以来,3D打印行业内好消...
DeepSeek V4永久降价... 快科技5月25日消息,DeepSeek近日更新API文档,宣布DeepSeek-V4-Pro模型在5...
俄外长告知美方对乌打击计划 新华社莫斯科5月25日电(记者侯鸣)俄罗斯外交部网站25日发布通告说,俄外交部长拉夫罗夫当天同美国国...
伊朗总统下令:恢复互联网至今年... △资料图当地时间25日晚,伊朗总统佩泽希齐扬下令恢复伊朗互联网至今年1月大规模断网前的状态。(总台记...
国家两部门:开展矿山机器人应用... 国家矿山安全监察局综合司 工业和信息化部办公厅关于开展矿山机器人应用验证试点工作的通知 国家矿山安全...
打造“终身学习之城”,杭州积极... 潮新闻客户端 记者 徐婷 俞刘东 通讯员 许慧敏 人工智能时代日新月异,培养适应时代生存发展的人才,...