最近在项目中需要对用户信息进行加密,因为这个项目还需要对加密的信息进行解密,所以不打算采用md5进行加密。在网上找了市面上常用的对称加密算法后,发现Aes算法比较推荐使用,所以最后选定了使用Aes。在使用Aes的过程中遇到了字符串被截断的问题,最后解决了,将经验分享出来记录一下。
我的问题是部分数据经过Aes加密后出现了/斜杠符号,由于使用的是thinkphp框架,而且tp的参数都是使用/斜杠进行分隔的,所以导致在将含有/斜杠符号的加密数据进行拼接的时候导致数据被截断,百度后无意中发现了php有一个将字符串转为16进制的方法:bin2hex($str),尝试了之后发现有效
代码如下:
$plainText = '7tXkOG1uTESIzhR6'; // 要加密的数据
$aes = new Aes('key'); // 实例化Aes类,并传递密钥key
// 加密 BFneJm/SGOU8qT4gUhOuDccXUw9B8yB1e0qhv68RxC4=
$cipherText = $aes->encrypt($plainText);
// 此时密文中含有/符号,不能直接传输,否则将无法正常传递回来,需要再对密文进行编码为16进制的字符串
$hexText = bin2hex($cipher); // 将字符串编码为16进制的字符串
// 42466e654a6d2f53474f55387154346755684f7544636358557739423879423165307168763638527843343d
可以看到此时就已经没有/符号了,可以放心拿来传输了
需要解密的时候再将16进制值转换回来就好了: