123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- <?php
- namespace miniprogram;
- use miniprogram\errorCode;
- class WXBizDataCrypt
- {
- private $appid;
- private $sessionKey;
-
- public function __construct( $appid, $sessionKey)
- {
- $this->sessionKey = $sessionKey;
- $this->appid = $appid;
- }
-
- 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::$IllegalEmpty;
- }
- if( $dataObj->watermark->appid != $this->appid )
- {
- return ErrorCode::$IllegalBuffer;
- }
- $data = $result;
- return ErrorCode::$OK;
- }
- }
|