ホームページ バックエンド開発 PHPチュートリアル PHP_PHP チュートリアルの中国語文字化けの一般的な解決策のまとめ

PHP_PHP チュートリアルの中国語文字化けの一般的な解決策のまとめ

Jul 15, 2016 pm 01:26 PM
php 中国語 文字化け 一般 よくある問題 開発する 要約する 方法 はい 解決する

PHP 中国語の文字化けは、PHP 開発でよくある問題の 1 つです。 PHP の中国語の文字化けは、Web ページ自体で発生することもあれば、MySQL の対話プロセスで発生することもあり、オペレーティング システムに関連していることもあります。ここに概要を示します。

1つ。 1 つ目は、PHP Web ページのエンコーディングです

1。php ファイル自体のエンコーディングと Web ページのエンコーディングは

a と一致する必要があります。gb2312 エンコーディングを使用する場合、php はヘッダーを出力する必要があります。 header(“Content-Type: text/html; charset =gb2312”)、静的ページに を追加します。すべてのファイルの形式は ANSI であり、メモ帳で開いて、ソース ファイルを上書きして ANSI にエンコードして保存できます。

b. utf-8 エンコーディングを使用する場合、php はヘッダーを出力する必要があります: header("Content-Type: text/html; charset=utf-8")、 の場合、すべてのファイルのエンコード形式は utf-8 です。 utf-8 として保存するのは少し面倒かもしれません。セッションを使用する場合は、editplus を使用して保存できます。パラメータの選択 -> ファイル -> UTF-8 署名で、[常に削除] を選択し、BOM 情報を削除します。

2. PHP 自体は Unicode ではないため、substr などのすべての関数を mb_substr に変更する必要があります (mbstring 拡張機能をインストールする必要があります)。または、iconv を使用してトランスコードできます。

Ⅱ。 PHP と Mysql 間のデータ対話 PHP とデータベースのエンコーディングは一貫している必要があります

1. mysql 設定ファイル my.ini または my.cnf を変更します。mysql には utf8 エンコーディングを使用するのが最適です

default-character-set= utf8

[mysqld]
default-character-set=utf8
default-storage-engine=MyISAM
[mysqld] の下に追加します:
default-collat​​ion=utf8_bin
init_connect='SET NAMES utf8'

2. 行う必要があること データベース操作用の PHP プログラムの前に mysql_query("set names 'encoding'"); を追加します。PHP エンコーディングが gb2312 の場合、mysql エンコーディングは gb2312 です。 . utf-8 であれば、mysql エンコーディングは utf8 になります。 このようにすると、データを取得するときに文字化けが発生しません

3. PHPはオペレーティングシステムと関係があります

WindowsとLinuxのエンコーディングが異なります。 Windows環境でPHP関数を呼び出す際、パラメータがutf-8エンコーディングの場合、move_uploaded_file()、filesize(などのエラーが発生します。 )、readfile( ) など。これらの関数は、アップロードとダウンロードの処理時によく使用されます。呼び出し時に次のエラーが発生する可能性があります:

警告: move_uploaded_file()[function.move-uploaded-file]: ストリームを開けませんでした: 無効です。 ...

の引数 警告: move_uploaded_file()[function.move-uploaded-file]:...

の '' を '' に移動できません 警告: filesize() [function.filesize]: stat が失敗しました.. . in ...

警告: readfile() [function.readfile]: ストリームを開けませんでした: ..

の引数が無効です。これらのエラーは、Linux 環境で gb2312 エンコーディングを使用する場合には発生しませんが、ファイル名保存後 文字化けによりファイルが読み込めない場合は、まずパラメータをオペレーティングシステムが認識するエンコードに変換することができます。エンコード変換には、mb_convert_encoding (文字列、新しいエンコード、元のエンコード) または iconv (元のエンコード) を使用できます。 、新しいエンコーディング、文字列)なので、処理後に保存されたファイル名は文字化けせず、正常に読み込むことができ、中国語名のファイルのアップロードとダウンロードが可能になります。

実際には、より良い解決策があります。それは、システムから完全に分離することです。そのため、システムのエンコーディングを考慮する必要はありません。ファイル名として文字と数字のみのシーケンスを生成し、データベースに漢字を含む元の名前を保存することができます。この方法では、ダウンロード時に move_uploaded_file() を呼び出すときに問題は発生しません。ファイル名を中国語の文字を含む元の名前に変更します。ダウンロードを実装するコードは以下の通りです

header("Pragma: public");

header("Expires: 0");

header("Cache-Component: must-revalidate, post-check=0, pre -check= 0");

header("Content-type: $file_type");

header("Content-Length: $file_size");

header("Content-Disposition:attachment; filename="$ file_name"" );

header("Content-Transfer-Encoding: binary");

readfile($file_path);

$file_type はファイルの種類、$file_name は元の名前、$file_path はファイルですサービスアドレスに保存されます。

4つ。文字化けが発生する理由をまとめてみましょう

文字化けが発生する原因は、一般的に 2 つあります。 1 つ目は、エンコード (文字セット) の設定が間違っているため、ブラウザが間違ったエンコードで解析し、画面が乱雑な「天国の本」でいっぱいになった後、ファイルが間違ったエンコードで開かれ、その後保存されました。たとえば、テキスト ファイルは元々 GB2312 でエンコードされていましたが、UTF-8 エンコードで開かれて保存されました。上記の文字化けコードの問題を解決するには、まず開発のどの側面にエンコーディングが関係しているかを知る必要があります:

1. ファイル エンコーディング: ページ ファイル (.html、.php など) 自体が保存されるエンコーディングを指します。 Notepad と Dreamweaver では、ページを開くときにファイルのエンコーディングが自動的に認識されるため、問題は少なくなります。ただし、ZendStudio はエンコーディングを自動的に認識しません。作業中に誤って間違ったエンコーディングでファイルを開き、変更を行った後にファイルを保存すると、文字化けしてしまいます。の文字が出てきます(しみじみ)。

2. ページ宣言のエンコーディング: HTML コード HEAD で、 を使用して、Web が何であるかをブラウザーに伝えることができます。ページはエンコーディングを使用します。現在、XXX は中国の Web サイト開発で主に GB2312 と UTF-8 を使用します。

3. データベース接続エンコーディング: データベース操作を実行する際にどのエンコーディングが使用されるかを指します。たとえば、MySQL の内部デフォルト エンコーディングは latin1 エンコーディングです。これは、MySQL が他のエンコーディングで Mysql に送信されたデータは latin1 エンコーディングに変換されることを意味します。 WEB 開発で使用されるエンコーディングについて理解します。文字化けの原因は次のとおりです。さまざまなエンコーディングのほとんどが ASCII 互換であるため、英語の記号は表示されず、中国語の文字は表示されません。運が悪いでしょう

5. よくあるエラーの状況と解決策: 1. データベースは UTF8 エンコーディングを使用しており、ページ宣言のエンコーディングは現時点では文字化けの最も一般的な原因です。 PHP スクリプトで直接 SELECT されたデータは文字化けします。クエリを実行する前に mysql_query("SET NAMES GBK"); を使用して MYSQL 接続エンコーディングを設定し、ページ宣言エンコーディングが接続エンコーディング セットと一致していることを確認する必要があります。ページが UTF-8 でエンコードされている場合は、ここで (GBK は GB2312 の拡張子です)、mysql_query("SET NAMES UTF8"); を使用できます。一般的に使用される UTF-8 ではなく、UTF8 であることに注意してください。ページによって宣言されたエンコーディングはデータベースの内部エンコーディングと一致するため、接続エンコーディングを設定する必要はありません

注: 実際には、MYSQL のデータ入力と出力は上記よりも複雑です。 MYSQL 設定ファイル my.ini で定義されたデフォルトのエンコーディング ([client] の default-character-set および [mysqld] の default-character-set ) クライアント接続とデータベースで内部的にデフォルトで使用されるエンコーディングを設定します。上記で指定したエンコーディングは、実際には、MYSQL クライアントがサーバーに接続するときに、デフォルトのエンコーディング

2 を使用するのではなく、受信したクライアント データのエンコーディングを MYSQL サーバーに伝えるためのコマンド ライン パラメーターです。ファイル自体のエンコーディングと一致しない場合、ページを作成したときに表示されるコードが文字化けするため、これはめったに起こりません。これは、ファイルを開いたときに発生するいくつかの小さなバグを将来修正する予定です。ページを間違ったエンコードで保存してしまいました。または、CuteFTP などの一部の FTP ソフトウェアを使用してオンラインでファイルを直接変更すると、ソフトウェアのエンコード設定が間違っているため、間違ったエンコードが変換されます。

3. バーチャルホストをレンタルした一部の友人は、上記の 3 つのエンコードが正しく設定されているにもかかわらず、依然として文字化けが発生していることに気づきました。たとえば、Web ページが GB2312 でエンコードされている場合、ブラウザのエンコードを手動で GB2312 に変更すると、Web ページの HEAD はすでに GB2312 として認識されます。 、ページは正常に表示されます。その理由は、サーバー Apache がサーバーのグローバルなデフォルト エンコーディングを設定し、httpd.conf に AddDefaultCharset UTF-8 を追加するためです。このとき、サーバーは最初に HTTP ヘッダーをブラウザーに送信しますが、その優先順位はページ内で宣言されたエンコーディングよりも高くなります。当然、ブラウザーはそれを誤って認識します。解決策は 2 つあります。管理者は、AddDefaultCharset GB2312 を独自の仮想マシンの構成ファイルに追加してグローバル構成をオーバーライドするか、独自のディレクトリの .htaccess で構成する必要があります。

要約: 一言で言えば、PHP の中国語の文字化けコードを解決する最善かつ最速の方法は、ページに適用されているページ番号がデータベースの内部エンコーディングと一致しない場合、ページによって宣言されたエンコーディングを一致させることです。データベースの内部エンコーディング、接続エンコーディングを設定します。 mysql_query("SET NAMES XXX ");

http://www.bkjia.com/PHPjc/446598.html

www.bkjia.com
  1. tru​​e
http://www.bkjia.com/PHPjc/446598.html
技術記事

PHP 中国語の文字化けは、PHP 開発においてよくある問題の 1 つです。 PHP の中国語の文字化けは、Web ページ自体で発生することもあれば、MySQL の対話プロセスで発生することもあり、オペレーティング システムに関連していることもあります。以下に入力してください...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

今まで知らなかったことを後悔している 7 つの PHP 関数 今まで知らなかったことを後悔している 7 つの PHP 関数 Nov 13, 2024 am 09:42 AM

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

母音を文字列にカウントするPHPプログラム 母音を文字列にカウントするPHPプログラム Feb 07, 2025 pm 12:12 PM

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? Apr 03, 2025 am 12:03 AM

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

See all articles