PHP JSON使用有效的JSON解码错误

时间:2016-02-24 03:58:16

标签: php json

我正在尝试解码一个简单的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));
}

1 个答案:

答案 0 :(得分:2)

额外的控制字符(\ 0)是由于密码块填充。来自mcrypt_decrypt文档

数据

  • 将使用给定的密码和模式解密的数据。如果 数据的大小不是n * blocksize,数据将被填充 与&#39; \ 0&#39;。

您可以在加密中自己填充块大小的输入,然后在decrypt()中删除额外的填充,或者您可以从解码的消息中修剪尾随的零字节,如下所示。

$decrypt = trim($decrypt, "\0");