ホームページ > バックエンド開発 > PHPチュートリアル > PHPでmssqlのjsonデータを読み込むときに中国語が文字化けする問題の解決策

PHPでmssqlのjsonデータを読み込むときに中国語が文字化けする問題の解決策

高洛峰
リリース: 2023-03-04 11:24:02
オリジナル
1461 人が閲覧しました

PHP と Web ページは UTF-8 エンコードを使用します。データベースは SQL Server2008 であり、デフォルトのエンコード (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 &#39;../conn.php&#39;;
$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&#39;$employeeID&#39;,N&#39;$employeeName&#39;,N&#39;$department&#39;, 
getdate(), getdate())";
}else{//如果seq已存在则更新已有记录
$query = "UPDATE employees SET employeeID=&#39;$employeeID&#39;, 
employeeName=&#39;$employeeName&#39;,department=&#39;$department&#39;,
updateTime=getdate() 
WHERE seq=&#39;$seq&#39;";
}
// 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;
?>
ログイン後にコピー

上記は、PHP で中国語の文字化けした mssql json データを読み取るためにエディターが紹介した解決策です。皆様のお役に立てれば幸いです。

PHP で mssql json データを読み取る際の中国語の文字化けの解決策に関するその他の関連記事については、PHP 中国語 Web サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート