PHP と Web ページは UTF-8 エンコーディングを使用します。データベースは SQL Server2008 であり、データベース データを読み取るときは、フロントエンドに返される json_encode() を使用します。中国人。以下では、Script House の編集者が PHP による mssql json データの中国語文字化けの解決策を紹介します。必要な友達は一緒に学ぶことができます
PHP と Web ページは UTF-8 エンコーディングを使用しています。デフォルトのエンコーディング (936、GBK エンコーディング) を使用します
データベースデータを読み取るとき、PHP に付属の json_encode() を使用してフロントエンドに戻ると、結果は中国語で表示されません。
解決策は次のとおりです:
このようにして、SQL Server 2008 の中国語を Web ページ上で正常に表示できるようになります。
SQL Server 2008 に通常通り中国語を挿入したい場合は、次のコードも追加する必要があります: $query = iconv("utf-8", "gbk//ignore", $query);//中国語の文字化けの問題を解決します
完全なコードは次のとおりです:
<?php /** * 如果员工编号在MySql中不存在则在MySql中插入员工记录 * 如果该员工编号已经存在则进行更新操作 */ //如果用JSON格式则要使用text/html,不能使用text/xml header("Content-Type: text/html;charset=utf-8"); // header("Content-Type: text/html;charset=GBK"); //告诉浏览器不要缓存数据 header("Cache-Control: no-cache"); require '../conn.php'; $seq = $_POST["seq"]; $employeeID = $_POST["employeeID"]; $employeeName = $_POST["employeeName"]; $department = $_POST["department"]; if(!isset($seq) || $seq == ""){//seq不存在则插入新记录 $query = "INSERT INTO employees (employeeID, employeeName, department, createTime, updateTime) VALUES (N'$employeeID',N'$employeeName',N'$department', getdate(), getdate())"; }else{//如果seq已存在则更新已有记录 $query = "UPDATE employees SET employeeID='$employeeID', employeeName='$employeeName',department='$department', updateTime=getdate() WHERE seq='$seq'"; } // file_put_contents("E:/mylog.log", $query."\r\n",FILE_APPEND);//用于调试 <span style="color:#FF0000;">$query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文乱码问题</span> if($result = sqlsrv_query($conn, $query)){ echo true; }else{ echo false; } // echo $query; ?>
概要: 上記がこの記事の全内容です。皆さんの学習に役立つことを願っています。
関連する推奨事項:
phpCodeIgniterに基づく画像のアップロードと切り取り機能の実装方法
のlocaleconv()関数の例の説明
以上がPHPでmssqlのjsonデータを読み込む際に中国語が文字化けする場合の解決策についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。