ホームページ  >  記事  >  バックエンド開発  >  mysql がデータを挿入すると、漢字が x87xE7xA7x91xE7x82 に変わります。

mysql がデータを挿入すると、漢字が x87xE7xA7x91xE7x82 に変わります。

WBOY
WBOYオリジナル
2016-06-23 14:24:561167ブラウズ

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 ではありません
この特殊な状況は元のプログラマの間違いから生じましたが、もう修正できません

ありがとうございます、どうやらこれが本当に問題のようです! !

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。