ホームページ >バックエンド開発 >PHPチュートリアル >PHP は json_decode を使用して json を解析し、NULL を返します
専門家の皆様にお聞きしたいのですが、json_decode で解析された $_POST['mypostdata'] 文字列が null になるのに、$_POST['mypostdata'] を php ファイルにコピーすると正常に解析できるのはなぜでしょうか。やるべきですか?アドバイスをお願いします!コードは次のとおりです:
b993c98b041124933eb5da29d961c22c';
?>
出力:
[["90987682","Chen Haoru","Management"],["309888729" .Zhang", "Management"],["56439871","jack","Management"],["76398723","李杰","e"]]
UTF-8
arr は null です
もちろん、投稿者は、この質問をする前に、インターネットで長い間情報を検索しました (例: http://www.nginx.cn/337)。前述の HTML 3 ソリューション:
1. json 文字列は二重引用符で囲む必要があります
$output = str_replace("'", '"', $output);
2. json 文字列は utf8 である必要がありますencoded
$output = iconv( 'gbk', 'utf8', $output);
3. 余分なカンマは使用できません。例: [1,2,]
正規表現で置き換えます。 ('/,s*([]}] )/m', '$1', $output)
1,2,3 の出力文字列形式では問題ないはずです。上記のエンコーディングも次のように出力されます。 UTF-8 ですが、実際はそうではありません。何が起こっているのかはわかっています。
さらに、投稿者が使用している PHP バージョン 5.2.6 では、json_last_error() を使用できないはずです。関数参照: http://php.net/manual/zh/function.json-last-error.php
json_last_error — 最後に発生したエラーを返します (PHP 5 >= 5.3.0、PHP 7)
---------------- ---区切り線: 作成者は、上の赤い部分の json 文字列を直接接続し、json 解析のために $member_info にコピーします。 post パラメータを通じて取得する場合 ------------------ --
fb9d9b81918ccad540fb3e8919f997b8';
} else {
foreach($ arr as $ele_arr) {
echo 'Name:'.$ele_arr[1]; echo '076402276aae5dbec7f672f8f4e5cc81';
}
}
?>
出力を印刷
[["90987682","Chen Haoru","Management"] ,["309888729","張さん","管理"],["56439871","ジャック","管理"],["76398723","李杰","e"]]
UTF -8
名前: Chen Haoru
名前: Zhang 氏
名前: jack
名前: Li Jie
まだ確信が持てないので質問します。上記は、 json形式で問題ないでしょうか?文字のエンコーディングはutf-8で問題ないでしょうか?
ディスカッションへの返信 (解決策)
echobase64_encode($ _POST['mypostdata']); 結果を投稿して分析させてください
これはbase64_encodeデータです、ありがとう!
$s = base64_decode("W1tcIjkwOTg3NjgyXCIsXCLpmYjlpb3ojLlcIixcIueuoeeQhlwiXSxbXCIzMDk4ODg3MjlcIixcIuW8oOWFiOeUn1wiLFwi566h55CGXCJdLFtcIjU2NDM5ODcxXCIsXCJqYWNrXCIsXCLnrqHnkIZcIl0sW1wiNzYzOTg3MjNcIixcIuadjua0gVwiLFwiZVwiXV0");echo $s;明らかに、 magic_quotes_gpc スイッチがオンになっていることがわかります (このスイッチは php5.4 では無効です)。
[[\"90987682\",\"陈好茹\",\"管理\"],[\"309888729\",\"张先生\",\"管理\"],[\"56439871\",\"jack\",\"管理\"],[\"76398723\",\"李洁\",\"e\"]]自動エスケープが使用されているため、データベースに直接保存されていない場合はエスケープする必要があります
if(get_magic_quotes_gpc()) { if(isset($_GET)) $_GET = unTurn($_GET); if(isset($_POST)) $_POST = unTurn($_POST);}//去转义function unTurn($val) { if(is_array($val)) { $val = array_map('unTurn', $val); }else { $val = stripslashes($val); } return $val;}
$s = base64_decode("W1tcIjkwOTg3NjgyXCIsXCLpmYjlpb3ojLlcIixcIueuoeeQhlwiXSxbXCIzMDk4ODg3MjlcIixcIuW8oOWFiOeUn1wiLFwi566h55CGXCJdLFtcIjU2NDM5ODcxXCIsXCJqYWNrXCIsXCLnrqHnkIZcIl0sW1wiNzYzOTg3MjNcIixcIuadjua0gVwiLFwiZVwiXV0");$s = stripcslashes($s);print_r(json_decode($s, true));
そうですね、やはりモデレーターは明確なアイデアを持っていて、すぐに問題を解決してくれて、ありがとうございました。スレッドを閉じることもできましたが、より多くの人に知ってもらうために、モデレーターにこの種の問題を解決した経験を共有してもらいたいと思います。
学びました。
とても使いやすく、わかりやすい