解决tp中因为Aes算法加密数据后出现斜杠/导致的字符串截断问题

        最近在项目中需要对用户信息进行加密,因为这个项目还需要对加密的信息进行解密,所以不打算采用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进制值转换回来就好了:

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值