mysql がデータを挿入すると、漢字が x87xE7xA7x91xE7x82 に変わります。
mysql;
次のテスト パラメータはサーバー側の php ファイルで定義されており、クライアントによって送信されません。$sqlstr データは adodb によって mssql データベースから読み取られ、読み取られた中国語のトランスコーディングは次のようになります。 ,"UTF-8" ,$str)
サーバーサイドの php ファイルを直接実行する場合は、mysql inert を直接実行しても問題ありません
しかし、クライアントから php にポストして mysql を実行すると、エラーが報告されます:
不正な文字列値: 行 1 の列 'typename' の 'x87xE7xA7x91xE7x82...'
echo $sqlstr の場合
出力: INSERT INTO dede_arctype SET id ='2001', reid ='1002', topid ='1002', sortrank ='50', typename ='婦人科炎症 ', typedir ='{cmspath}/a' 問題ありません
mysql-front で直接実行します:
INSERT INTO dede_arctype SET id ='2001', reid ='1002'、topid ='1002'、sortrank ='50'、typename ='婦人科炎症'、typedir ='{cmspath}/a' 問題ありません
これはなぜですか? ? ?
ディスカッションに返信 (解決策)
ただし、クライアントが php に投稿して mysql を実行すると、エラーが報告されます:
不正な文字列値: 'x87xE7xA7x91xE7x82...' for columns 'typename' at row 1
投稿したデータのエンコーディングを変換します
$typename = iconv("UTF-8", "UTF-8", $typename);
utf-8 から utf-8 に変換しようとしています
トランスコーディングはありません
echo base64_encode($str);
結果を投稿します
トランスコーディングはありません
echo Base64_encode ($str);
結果を投稿
/ljLvpmaLlpofnp5Hmi6XmnInkuIDmlK/nlLHlpJrlkI3otYTmt7HkuJPlrrbjgIHkuLvmsrvljLvluIjjgIHkuLvnrqHmiqTluIjnu4TmiJDnmoQuLi4nLA0 KICAgICAgICAgICAgICAgICAgICAgICAgICAga2V5d29yZHMgICA9J+a3seWcs+Wmh+enkSzkurrmtYEs55eb57uPLOeUn+auluWZqCzlrqvpoojnlr7nl4Us5awz5oCnLOeCjueXhyzogr/nmKQs5pu0Li4uJ y wNCiAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlb3RpdGxlICAgPSfmgZLnlJ/lpofnp5En
INSERT INTO dede_arctype SET id ='1002', reid ='0', topid ='0', sortrank ='0', typename ='恒生妇科', typedir ='{cmspath}/ahsfk', isdefault ='1', tempindex ='{style}/index_article.htm', templist ='{style}/list_article.htm', temparticle='{style}/article_article.htm', namerule ='{typedir}/{Y}{M}{D}/{aid}.html', namerule2 ='{typedir}/list_{tid}_{page}.html', description='恒生医院妇科拥有一支由多名资深专家、主治医师、主管护师组成的...', keywords ='深圳妇科,人流,痛经,生殖器,宫颈疾病,女性,炎症,肿瘤,更...', seotitle ='恒生妇科'
mysql_query('set names utf8' はありましたか? ); 挿入する前に?
INSERT INTO dede_arctype SET id ='1002', reid ='0', topid ='0', sortrank ='0', typename ='恒生妇科', typedir ='{cmspath}/ahsfk', isdefault ='1', tempindex ='{style}/index_article.htm', templist ='{style}/list_article.htm', temparticle='{style}/article_article.htm', namerule ='{typedir}/{Y}{M}{D}/{aid}.html', namerule2 ='{typedir}/list_{tid}_{page}.html', description='恒生医院妇科拥有一支由多名资深专家、主治医师、主管护师组成的...', keywords ='深圳妇科,人流,痛经,生殖器,宫颈疾病,女性,炎症,肿瘤,更...', seotitle ='恒生妇科'
挿入する前に mysql_query('set names utf8'); を実行しましたか?
$db->Execute("SET NAMES UTF-8");
INSERT INTO dede_arctype SET id ='1002', reid ='0', topid ='0', sortrank ='0', typename ='恒生妇科', typedir ='{cmspath}/ahsfk', isdefault ='1', tempindex ='{style}/index_article.htm', templist ='{style}/list_article.htm', temparticle='{style}/article_article.htm', namerule ='{typedir}/{Y}{M}{D}/{aid}.html', namerule2 ='{typedir}/list_{tid}_{page}.html', description='恒生医院妇科拥有一支由多名资深专家、主治医师、主管护师组成的...', keywords ='深圳妇科,人流,痛经,生殖器,宫颈疾病,女性,炎症,肿瘤,更...', seotitle ='恒生妇科'
挿入する前に mysql_query('set names utf8'); を実行しましたか?
$db->Execute("SET NAMES UTF-8");
トランスコーディングなし
echobase64_encode($str);
結果を投稿します
兄弟: データベースに挿入して表示します: å?宫 å? …è??ç?? このような文字化けは、
echo $typename; と表示される場合: u4e0du80b2u4e0du5b55'u6210u529f
これはなぜですか? ? ?
$db->Execute("SET NAMES UTF-8"); ? ?
それが問題です!
$db->Execute("SET NAMES UTF8");
mysql の utf-8 文字セットの名前は utf8 ですが、これは utf-8 ではありません
この特殊な状況は元のプログラマの間違いから生じましたが、もう修正できません
クライアントからサーバーに渡されるフォームデータの URL 文字列をエンコードするには、urlencode() を実装します
実行: urlencode() クライアントからサーバーに渡されるフォームデータの URL 文字列をエンコードします
クライアントは特定のデータを渡しません。動作条件のみを渡します
$db->Execute("SET NAMES UTF-8 ");? ? ?
それが問題です!
$db->Execute("SET NAMES UTF8");
mysql の utf-8 文字セットの名前は utf8 ですが、これは utf-8 ではありません
この特殊な状況は元のプログラマの間違いから生じましたが、もう修正できません
ありがとうございます、どうやらこれが本当に問題のようです! !

ホット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)

ホットトピック









PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。
