開発プロセス中に、JSON データがデータベースに保存される状況に遭遇することがあります。英語の文字列を扱う場合には通常問題はありませんが、中国語の文字を扱う場合には文字化けが発生する可能性があります。この記事では、MySQL データベースに漢字を格納するときに発生する JSON 文字化けの問題を解決する方法を紹介します。
まず、データベース文字セットが正しいかどうかを確認する必要があります。 MySQL のデフォルトの文字セットは Latin1 であり、中国語の文字セットはサポートされていません。エンコードが UTF-8 でない場合は、MySQL の文字セットを変更する必要があります。 MySQL コマンド ラインで、次のコマンドを入力して文字セットを変更します:
SET NAMES 'utf8';
次に、次のコマンドを実行します:
ALTER DATABASE `your_database` CHARACTER SET utf8 COLLATE utf8_general_ci;
別の FAQ それはエンコードの問題です。テキスト エディタでは、サーバーとは異なるエンコーディングが使用されているか、MySQL データベースとは異なるエンコーディングが使用されている可能性があります。文字化けを避けるために、すべてのファイルが同じエンコーディングを使用していることを確認してください。 php ファイルの場合は、UTF-8 エンコードを使用することをお勧めします。
開発プロセス中、JSON データを保存する最良の方法は、PHP の json_encode 関数を使用してデータを JSON 文字列に変換することです。それをデータベーステーブルに挿入します。中国語の文字の場合は、UTF-8 エンコード形式が必要です。
JSON データを MySQL データベースに格納するサンプル コードは次のとおりです。
//连接数据库 $conn = mysqli_connect($servername, $username, $password, $dbname); //设置字符集 mysqli_set_charset($conn, "utf8"); //将 JSON 数据转换为字符串 $json_data = json_encode($data, JSON_UNESCAPED_UNICODE); //插入数据到数据库表中 $sql = "INSERT INTO `table` (`id`, `data`) VALUES (NULL, '$json_data')"; $result = mysqli_query($conn, $sql); //关闭数据库连接 mysqli_close($conn);
データを読み取りたい場合JSON 文字列内の JSON データを操作する場合、PHP の json_decode 関数を使用して、JSON 文字列を PHP 配列またはオブジェクトに変換できます。 json_decode を使用する場合、データがオブジェクトではなく配列として返されるように、2 番目のパラメーターを true に設定する必要があることに注意してください。
次は、MySQL データベースから JSON データを読み取るためのサンプル コードです:
//连接数据库 $conn = mysqli_connect($servername, $username, $password, $dbname); //设置字符集 mysqli_set_charset($conn, "utf8"); //查询数据库 $sql = "SELECT `data` FROM `table` WHERE id = '1'"; $result = mysqli_query($conn, $sql); $row = mysqli_fetch_assoc($result); //将 JSON 字符串转换为 PHP 数组 $json_data = json_decode($row['data'], true); //关闭数据库连接 mysqli_close($conn);
概要:
JSON データを保存するときは、データベースの文字セットが UTF- であることを確認してください。 8. テキスト エディターは正しいエンコード形式を使用し、PHP の json_encode 関数を使用してデータを JSON 文字列に変換します。 JSON データを読み取るときは、PHP の json_decode 関数を使用して、JSON 文字列を PHP 配列に変換します。
上記は、MySQL データベースに中国語の文字を保存するときに発生する JSON 文字化けの問題を解決するためのヒントです。
以上がphp jsonがデータベースに中国語の文字化けを保存した場合の対処方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。