aes 加密解密类

本文介绍了一种使用AES加密标准实现的加密和解密方法。该方法通过PHP语言实现,利用mcrypt扩展来完成对字符串的安全加密过程。文章详细解释了加密流程,包括填充操作、初始化向量的创建及加密数据的转换等步骤,并提供了相应的解密过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/**
* ASE加密
* @param String input@paramStringkey 私钥
* return String data/publicstaticfunctionASEencrypt(input, key) {size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
input=self::pkcs5pad(input, size);td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, ”, MCRYPT_MODE_ECB, ”);
iv=mcryptcreateiv(mcryptencgetivsize(td), MCRYPT_RAND);
mcrypt_generic_init(td,key, iv);data = mcrypt_generic(td,input);
mcrypt_generic_deinit(td);mcryptmoduleclose(td);
data=strtoupper(bin2hex(data));
return $data;
}

public static function pkcs5_pad ($text, $blocksize) {
    $pad = $blocksize - (strlen($text) % $blocksize);
    return $text . str_repeat(chr($pad), $pad);
}

/**
 * ASE解密
 * @param String $sStr 需要解密的字符串
 * @param String $sKey 私钥
 * return  String $data解密结果
 */
public static function ASEdecrypt($sStr, $sKey) {
    $decrypted= mcrypt_decrypt(
        MCRYPT_RIJNDAEL_128,
        $sKey,
        base64_decode($sStr),
        MCRYPT_MODE_ECB
    );
    $dec_s = strlen($decrypted);
    $padding = ord($decrypted[$dec_s-1]);
    $decrypted = substr($decrypted, 0, -$padding);
    return $decrypted;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值