PHP AES cbc模式 pkcs7 128加密解密

今天在对接一个第三方接口的时候,对方需要AES CBC模式下的加密。这里简单写一个demo


class Model_Junjingbao extends Model
{

    private static $_partnerKey  = ‘6d70a09e4d0f8095‘;
    //获取库存,更新价格信息
    public static function test($productId=2780)
    {

        $data = array(
            ‘productId‘=>$productId,
            ‘startTime‘=>‘2018-04-09‘,
            ‘endTime‘=>‘2018-04-10‘
        );

         $str = json_encode($data);
        $xcrypt =  self::aes_cbc_pkpadding($str);

        var_dump($xcrypt);//加密结果
        var_dump(self::aes_cbc_pkpadding_back($xcrypt));//解密结果
    }

    //AES加密数据
    private static function aes_cbc_pkpadding($str)
    {

        $block= mcrypt_get_block_size(MCRYPT_RIJNDAEL_128,MCRYPT_MODE_CBC);
        $pad=$block-(strlen($str)%$block);
        if($pad<=$block) {
            $char=chr($pad);
            $str.=str_repeat($char,$pad);
        }
        $xcrypt = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, self::$_partnerKey, $str, MCRYPT_MODE_CBC);

        return $xcrypt;
    }

    //AES解密数据
    private static function aes_cbc_pkpadding_back($xcrypt)
    {

        $string = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, self::$_partnerKey, $xcrypt, MCRYPT_MODE_CBC);
        $slast = ord(substr($string, -1));
        $slastc = chr($slast);
        if (preg_match("/$slastc{" . $slast . "}/", $string)) {
            $string = substr($string, 0, strlen($string) - $slast);
            return $string;
        } else {
            return false;
        }
    }

}

执行test方法

加密结果


øæ׌“j·A" OÈ[ótcÚ‡2Y‰XXÒ¦½™Ép¬p[DâFw`?oàá¹d&x4(çôl£‰¡±Ü‘I¾‘ä YÖsÓd°Ý·^$’4höè¶Â÷GÂ)

解密结果


{"productId":2780,"startTime":"2018-04-09","endTime":"2018-04-10"}

原文地址:https://www.cnblogs.com/cnsanshao/p/12187564.html

时间: 2025-01-07 09:47:25

PHP AES cbc模式 pkcs7 128加密解密的相关文章

php AES cbc模式 pkcs7 128位加密解密(微信小程序)

PHP AES CBC模式PKCS7 128位加密 加密: $key = '1234567812345678'; $iv = '1234567890123456'; $message = '123456'; $blocksize = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC); $len = strlen($message); //取得字符串长度 $pad = $blocksize - ($len % $blocksiz

python AES CBC模式加密

今天需要用到AES CBC模式加密,搜索了很久,终于加密成功,记录一下今天的理解. 首先要安装pycrypto库,不知道为什么在windows安装失败,在linux可以正常安装 http://tool.chacuo.net/cryptaes,https://tools.lami.la/jiami/aes,以下代码加密后结果与这两个网页加密后一样. 这里有几点要注意,key的长度要是16,24或32,text的长度要是16的倍数,不满足长度都会补全,补全的字符可以自己定义,比如key补全不一定要"

AES CBC模式下的Padding Oracle解密

*/--> pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-color: #292b

AES .net 、JS 相互加密解密

/// <summary> /// AES加密 /// </summary> public class AES { /// <summary> /// 加密 /// </summary> /// <param name="toEncrypt"></param> /// <param name="key"></param> /// <returns></r

解决AES算法CBC模式加密字符串后再解密出现乱码问题

问题 在使用 AES CBC 模式加密字符串后,再进行解密,解密得到的字符串出现乱码情况,通常都是前几十个字节乱码: 复现 因为是使用部门 cgi?AESEncryptUtil 库,找到问题后,在这里复现不太方便,这里使用 python 进行复现,可以方便复现. #!/usr/bin/env python #coding=utf-8 from Crypto.Cipher import AES ? PADDING = '\0' if __name__ == "__main__":? ?

RSA AES 前端JS与后台JAVA的加密解密的是实现

AES CryptoJS 前提是编码方式,key,vi中设置一样,就可以进行跨语言加密解密 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 <link rel="stylesheet" href="<%=

分组密码模式: CBC模式(密码分组链接模式)

CBC模式是将前一个密文分组与当前明文分组的内容混合起来进行加密的,这样就可以避免ECB模式的弱点. 在CBC模式中,首先将明文分组与前一个密文分组进行XOR运算,然后再进行加密,如下图所示: 如果将一个分组的加密过程分离出来,我们就可以很容易地比较出ECB模式和CBC模式的区别,ECB模式只进行了加密,而CBC模式则在加密之前进行了一次XOR,如下图所示: 当加密第一个明文分组时,由于不存在“前一个密文分组”,因此需要事先准备一个长度为一个分组的比特序列来代替“前一个密文分组”,这个比特序列称

Qt使用AES加密算法对字符串进行加密

因工作需要,需要对字符串进行加密处理,在网上找了很长时间,终于找到了一个可以使用的aes加密算法.其源代码采用c++编写而成,但其头文件引用windows.h,经过修改部分代码,将#include<windows.h>去掉,这样可是使用与多个编译器.下面的代码中列出了测试用的代码(中文出现乱码现象): 点击(此处)折叠或打开 int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); TAesClass *aes = n

AES加密解密 助手类 CBC加密模式

string str = "2018"; string result1 = AESHelper.AesEncrypt(str); string result2 = AESHelper.AesDecrypt(result1); namespace Demo { /// <summary> /// AES加密解密 助手类 /// CBC加密模式 /// </summary> public class AESHelper { /// <summary> /