我正在尝试解码一个简单的 JSON 字符串和格式以使其看起来正确。我实际上复制了字符串并使用相同的算法进行解码,但没有所有额外的代码并且工作正常。
print_r(json_decode('{"user_id":1,"issused":"2016-02-24 04:40:17","expire":"2016-03-02 04:40:17"}'));
成功了。但是当我这样做的时候
$hash = Hash::salt(32);
$issused = date('Y-m-d H:i:s');
$expire = date('Y-m-d H:i:s', strtotime('+1 week'));
$data = array('user_id' => 1, 'issused' => $issused, 'expire' => $expire);
$encrypt = Cipher::encrypt(json_encode($data), $hash);
$decrypt = Cipher::decrypt($encrypt, $hash);
echo $encrypt;
echo "<br><br>";
echo $decrypt;
echo "<br><br>";
print_r(json_decode($decrypt));
其中 $decrypted
是我在上面发布的有效格式化 JSON。当我使用时:
echo json_last_erro();
它给了我 3 的输出,即 JSON_ERROR_CTRL_CHAR
知道为什么没有正确解码吗?
编辑 这是我加密数据的方式。
class Cipher {
public static function encrypt($string, $hash) {
$size = mcrypt_get_iv_size(MCRYPT_BLOWFISH, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($size, MCRYPT_RAND);
$encrypted = mcrypt_encrypt(MCRYPT_BLOWFISH, $hash, utf8_encode($string), MCRYPT_MODE_ECB, $iv);
//$encoded = urlencode($encrypted);
$encoded = base64_encode($encrypted);
return $encoded;
}
public static function decrypt($string, $hash) {
//$decoded = urldecode($string);
$decoded = base64_decode($string);
$size = mcrypt_get_iv_size(MCRYPT_BLOWFISH, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($size, MCRYPT_RAND);
$decrypted = mcrypt_decrypt(MCRYPT_BLOWFISH, $hash, $decoded, MCRYPT_MODE_ECB, $iv);
return $decrypted;
}
下面是我如何制作盐。
public static function salt($length) {
return mcrypt_create_iv($length); //base64_encode(openssl_random_pseudo_bytes($length));
}
最佳答案
额外的控制字符 (\0) 是由于密码 block 填充。来自mcrypt_decrypt文档
数据
- 将使用给定的密码和模式解密的数据。如果 数据的大小不是n * blocksize,数据将被填充 用'\0'。
您可以自己在加密中填充 block 大小的输入,然后在 decrypt() 中删除额外的填充,或者您可以从解码消息中删除尾随零字节,执行以下操作。
$decrypt = trim($decrypt, "\0");
关于使用有效 JSON 的 PHP JSON 解码错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35592971/