为了账号安全,请及时绑定邮箱和手机立即绑定

微信小程序登录,服务端解密有几率-41003

微信小程序登录,服务端解密有几率-41003

PHP
HUX布斯 2019-03-14 03:19:11
服务器是将unionId作为唯一id的,需要使用WXBizDataCrypt.decryptData将encryptedData解密出来。不过在调用WXBizDataCrypt.decryptData的时候总是又会30%的几率解密失败,返回errorCode -41003 服务器端语言:PHP (Laravel框架) 报错为:openssl_decrypt(): IV passed is only 15 bytes long…ects an IV of precisely 16 bytes, padding with 0 补充:每次小程序获取到iv的值中间有空格的,就会出错 成功的iv例子:$iv = "MLbq\/WIGb1YHk8f0GWmzLA==" 出错的iv例子:$iv = "shNiHyqyaVamI Fe\/YHUjw==" WXBizDataCrypt类 <?php namespace App\Libs\WeChat; use App\Libs\WeChat\errorCode; /** * 对微信小程序用户加密数据的解密示例代码. * * @copyright Copyright (c) 1998-2014 Tencent Inc. */ class WXBizDataCrypt { private $appid; private $sessionKey; public function __construct( $appid, $sessionKey) { $this->sessionKey = $sessionKey; $this->appid = $appid; } /** * 构造函数 * @param $sessionKey string 用户在小程序登录后获取的会话密钥 * @param $appid string 小程序的appid */ public function WXBizDataCrypt( $appid, $sessionKey) { $this->sessionKey = $sessionKey; $this->appid = $appid; } /** * 检验数据的真实性,并且获取解密后的明文. * @param $encryptedData string 加密的用户数据 * @param $iv string 与用户数据一同返回的初始向量 * @param $data string 解密后的原文 * * @return int 成功0,失败返回对应的错误码 */ public function decryptData( $encryptedData, $iv, &$data ) { if (strlen($this->sessionKey) != 24) { return ErrorCode::$IllegalAesKey; } $aesKey=base64_decode($this->sessionKey); if (strlen($iv) != 24) { return ErrorCode::$IllegalIv; } $aesIV=base64_decode($iv); $aesCipher=base64_decode($encryptedData); $result=openssl_decrypt( $aesCipher, "AES-128-CBC", $aesKey, 1, $aesIV); $dataObj=json_decode( $result ); if( $dataObj == NULL ) { return ErrorCode::$IllegalBuffer; } if( $dataObj->watermark->appid != $this->appid ) { return ErrorCode::$IllegalBuffer; } $data = $result; return ErrorCode::$OK; } }
查看完整描述

1 回答

?
侃侃尔雅

TA贡献1801条经验 获得超16个赞

【结贴】iv小程序端请求的时候用encodeURIComponent函数进行urlencode就好了(空格其实是符号:+ ?)

查看完整回答
反对 回复 2019-03-18
  • 1 回答
  • 0 关注
  • 1087 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信