json_decode 返回 NULL ,UTF-8 BOM

Nav*_*ngh 6 php json byte-order-mark utf-8

我想使用 json_decode 函数解码 JSON 数据并将其存储到数组中,但它返回 NULL 值。我认为这是因为UTF-8 BOM。有什么解决办法吗?我使用 Windows7 操作系统和 xampp。我将编码设置为

header('Content-type:application/json; charset=utf-8');
Run Code Online (Sandbox Code Playgroud)

JSON数据

{"command":"E101","user_id":"someuser","movie_id":"1","link_id":"2"}
Run Code Online (Sandbox Code Playgroud)

JSON 错误:控制字符错误,可能编码错误

 $json_errors = array(
     JSON_ERROR_NONE => 'No error has occurred',
     JSON_ERROR_DEPTH => 'The maximum stack depth has been exceeded',
     JSON_ERROR_CTRL_CHAR => 'Control character error, possibly incorrectly encoded',
     JSON_ERROR_SYNTAX => 'Syntax error',
    );
    echo 'Last error : ', $json_errors[json_last_error()], PHP_EOL, PHP_EOL;
Run Code Online (Sandbox Code Playgroud)

如果我解析此 JSON,则不会发生错误

 {"command":"E101","user_id":"someuser","movie_id":"movie_id","link_id":"link_id"}
Run Code Online (Sandbox Code Playgroud)

唯一的区别是我将字符串数据存储到 movie_id 和 link_id 中。为什么会发生这样的事?

JSON数据Bin2Hex()7b22636f6d6d616e64223a2245313031222c226d6f7669655f6964223a226d6f7669655f6964222c226c696e6b5f6964223a226c696e6b5f696 4227d00000000

我通过客户端加密 JSON 数据,在服务器端解密。

这是我的加密函数

    public function ajax_enc($data){

    $vector = "myvector";
    $filter = new Zend_Filter_Encrypt(array('adapter' => 'mcrypt', 'key' => $this->_AJAXKEY));
    $filter->setVector($vector);
    $encrypted = $filter->filter($data);
    // bin2hex for user use case     
    return bin2hex($encrypted); // rawurlencode(..) works

    }
Run Code Online (Sandbox Code Playgroud)

解密

public function ajax_dec($data)
{
$vector = "myvector";
$filter = new Zend_Filter_Decrypt(array('adapter' => 'mcrypt', 'key' => $this->_AJAXKEY ));
$filter->setVector($vector);
$decoded = pack('H*', $data);
$decrypted = $filter->filter($decoded);
return $decrypted;
}
Run Code Online (Sandbox Code Playgroud)

dec*_*eze 3

您的解密显然在字符串末尾留下了一堆填充 NUL 字节。

修复您的解密机制或修剪它们:trim($json, "\x0")