php5.4 より前の json バージョンは、中国語コンテンツをエスケープしないソリューションをサポートしていません。_PHP チュートリアル
php5.4 より前の JSON バージョンは、中国語コンテンツをエスケープしない解決策をサポートしていません。
この記事の例では、php5.4 より前のバージョンの json がエスケープされていない中国語コンテンツをサポートしていないという問題の解決策について説明します。参考のためにみんなで共有してください。具体的な分析は次のとおりです:
ERP インターフェースを記述するとき、JAVA 側はこの json_encoded コンテンツを受け取ります
このうち「creator」:「u751fu6d3bu7528u54c1u6d4bu8bd5u5c0fu5c4b」は中国語であり、現在はUTF8を使用しています。しかし、JAVA 側はこれを受け取ると、エスケープされた中国語を自動的に中国語に戻します。署名の計算方法はこれに基づいており、当然、署名は正しくありません。
PHP マニュアルを確認したところ、5.4 より前のバージョンでは漢字をエスケープする必要があることがわかりましたが、サーバー上の PHP バージョンは 5.3 であるため、PHP を使用して JSON メソッドをシミュレートしました。
if (version_compare(PHP_VERSION, '5.4.0') >= 0) {
関数 json_encode_ex($var) {
return json_encode($var, JSON_UNESCAPED_UNICODE);
}
} その他 {
関数 json_encode_ex($var) {
if ($var === null)
'null' を返します;
if ($var === true)
'true' を返します;
if ($var === false)
'false' を返します;
static $reps = array(
array("\", "/", "n", "t", "r", "b", "f", '"', ),
array('\\', '\/', '\n', '\t', '\r', '\b', '\f', '"', ),
);
if (is_scalar($var))
return '"' . str_replace($reps[0], $reps[1], (string) $var) . '"';
if (!is_array($var))
throw new Exception('JSON エンコーダ エラー!');
$isMap = false;
$i = 0;
foreach (array_keys($var) as $k) {
If (!is_int($k) || $i++ != $k) {
$isMap = true;
休憩;
}
}
$s = array();
if ($isMap) {
foreach ($var as $k => $v)
$s[] = '"' . $k . '":' . call_user_func(__FUNCTION__, $v);
'{' を返します ',', $s) ;
} else {
foreach ($var を $v として)
$s[] = call_user_func(__FUNCTION__, $v);
'[' を返します (',', $s) ';
}
}
}
使用する場合は、組み込み関数として直接使用してください。 json_encode_ex(array('釣魚島'=>'中国')); は多次元配列もサポートしています。
この記事で説明した内容が皆様の PHP プログラミング設計に役立つことを願っています。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









AJAXを使用してサーバーからデータを取得する場合の文字化けコードのソリューション:1。サーバー側コード(UTF-8など)の正しい文字エンコードを設定します。 2. AJAXリクエストでリクエストヘッダーを設定し、受け入れられている文字エンコード(Accept-Charset)を指定します。 3.ブートストラップテーブルの「UNESCAPE」コンバーターを使用して、脱出したHTMLエンティティを元の文字にデコードします。

ブートストラップリストのデフォルトスタイルは、CSSオーバーライドで削除できます。より具体的なCSSルールとセレクターを使用し、「近接原理」と「重量原理」に従って、ブートストラップのデフォルトスタイルをオーバーライドします。スタイルの競合を避けるために、よりターゲットを絞ったセレクターを使用できます。オーバーライドが失敗した場合は、カスタムCSSの重量を調整します。同時に、パフォーマンスの最適化に注意を払い、重要な!の過剰使用を避け、簡潔で効率的なCSSコードを書いてください。

次の手順を使用して、NAVICATがデータベースに接続できない問題を解決できます。サーバー接続を確認し、サーバーが実行されていることを確認、アドレス指定、ポートを正しく確認し、ファイアウォールにより接続を許可します。ログイン情報を確認し、ユーザー名、パスワード、許可が正しいことを確認します。ネットワーク接続を確認し、ルーターやファイアウォールの障害などのネットワークの問題をトラブルシューティングします。一部のサーバーでサポートされていない場合があるSSL接続を無効にします。データベースバージョンをチェックして、NAVICATバージョンがターゲットデータベースと互換性があることを確認してください。接続タイムアウトを調整し、リモートまたは遅い接続の場合は、接続タイムアウトタイムアウトを増やします。その他の回避策は、上記の手順が機能していない場合は、別の接続ドライバーを使用してソフトウェアを再起動したり、データベース管理者または公式NAVICATサポートに相談したりすることができます。

MySQLのインストールエラーのソリューションは次のとおりです。1。システム環境を慎重に確認して、MySQL依存関係ライブラリの要件が満たされていることを確認します。異なるオペレーティングシステムとバージョンの要件は異なります。 2.エラーメッセージを慎重に読み取り、依存関係のインストールやSUDOコマンドの使用など、プロンプト(ライブラリファイルの欠落やアクセス許可など)に従って対応する測定値を取得します。 3.必要に応じて、ソースコードをインストールし、コンパイルログを慎重に確認してみてください。これには、一定量のLinuxの知識と経験が必要です。最終的に問題を解決する鍵は、システム環境とエラー情報を慎重に確認し、公式の文書を参照することです。

MySQL接続は、次の理由が原因である可能性があります。MySQLサービスは開始されず、ファイアウォールは接続をインターセプトし、ポート番号が間違っています。ユーザー名またはパスワードが間違っています。My.cnfのリスニングアドレスは不適切に構成されています。トラブルシューティング手順には以下が含まれます。 2.ファイアウォール設定を調整して、MySQLがポート3306をリッスンできるようにします。 3.ポート番号が実際のポート番号と一致していることを確認します。 4.ユーザー名とパスワードが正しいかどうかを確認します。 5. my.cnfのバインドアドレス設定が正しいことを確認してください。

ルートとしてMySQLにログインできない主な理由は、許可の問題、構成ファイルエラー、一貫性のないパスワード、ソケットファイルの問題、またはファイアウォール傍受です。解決策には、構成ファイルのBind-Addressパラメーターが正しく構成されているかどうかを確認します。ルートユーザー許可が変更されているか削除されてリセットされているかを確認します。ケースや特殊文字を含むパスワードが正確であることを確認します。ソケットファイルの許可設定とパスを確認します。ファイアウォールがMySQLサーバーへの接続をブロックすることを確認します。

VUEのデフォルトのエクスポートが明らかになります:デフォルトのエクスポート、名前を指定せずにモジュール全体を一度にインポートします。コンポーネントはコンパイル時にモジュールに変換され、使用可能なモジュールはビルドツールを介してパッケージ化されます。名前付きのエクスポートと組み合わせて、定数や関数などの他のコンテンツをエクスポートできます。よくある質問には、循環依存関係、パスエラー、およびビルドエラーが含まれ、コードとインポートステートメントを慎重に調べる必要があります。ベストプラクティスには、コードセグメンテーション、読みやすさ、コンポーネントの再利用が含まれます。

ブートストラップテーブルを使用して中国の文字盤を表示するソリューション:1。PHP文字セットをUTF-8に設定します。 2. PHPスクリプトで文字セットを設定します。 3.データベース文字セットがUTF-8であることを確認してください。 4.ブートストラップテーブルの文字セットを「Zh-Cn」に設定します。 5。Mbstringを使用して、キャストキャラクターセットを拡張します。 6.他のエンコーディングからのトランスコードデータ。 7.ブラウザエンコーディングを確認します。
