我正在尝试解码一个简单的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 :(得分:2)
额外的控制字符(\ 0)是由于密码块填充。来自mcrypt_decrypt文档
数据强>
您可以在加密中自己填充块大小的输入,然后在decrypt()中删除额外的填充,或者您可以从解码的消息中修剪尾随的零字节,如下所示。
$decrypt = trim($decrypt, "\0");