phpページはgbkエンコードされています
phpページはbig5でエンコードされています
通常、上記のコードはphpページのトップページに配置されます。 PHP ページのエンコーディングを実装するためにヘッダーを使用するかメタを使用するかの違い 1. ページのエンコード 1. タグを使用してページエンコーディングを設定します このタグの目的は、クライアントのブラウザがページを表示するために使用する文字セット エンコーディングを宣言することです。xxx には gb2312、gbk、utf-8 (mysql の utf8 とは異なります) などを指定できます。したがって、ほとんどのページはこのメソッドを使用して、このページを表示するときに使用するエンコーディングをブラウザーに指示し、エンコーディング エラーや文字化けを回避できます。しかし、場合によっては、この文がどの xxx であっても機能しないことがわかります。これについては後で説明します。 は HTML 情報に属し、サーバーが HTML 情報をブラウザーに渡したことを示す単なるステートメントであることに注意してください。 2. header("content-type:text/html; charset=xxx"); この関数 header() の機能は、括弧内の情報を http ヘッダーに送信することです。 括弧内の内容が記事に記載されている通りであれば、機能は基本的にタグと同じです。最初のものと比較すると、文字が似ていることがわかります。ただし、違いは、この機能がある場合、ブラウザは常に要求された xxx エンコーディングを使用し、決して従わないことです。そのため、この機能は非常に便利です。なぜそうなるのでしょうか?次に、https ヘッダーと HTML 情報の違いについて話さなければなりません: https ヘッダーは、http プロトコルを使用して HTML 情報をブラウザーに送信する前にサーバーによって送信される文字列です。 metaタグはhtml情報に属するため、header()で送信した内容が先にブラウザに届きますが、metaよりもheader()の方が優先される点が人気です(言えるかわかりませんが)。 header("content-type:text/html; charset=xxx") と の両方を含む PHP ページを追加すると、ブラウザーは前の http ヘッダーのみを認識し、メタは認識しません。もちろん、この関数は PHP ページ内でのみ使用できます。 また、前者は確実に機能するのに、後者は機能しないことがあるのはなぜでしょうか?という疑問も残ります。これが、次に Apache について話したい理由です。 3.デフォルトの文字セットを追加します Apache のルート ディレクトリの conf フォルダーには、Apache 設定ドキュメント全体である httpd.conf があります。 httpd.conf をテキスト エディタで開きます (バージョンによって異なる場合があります) には、adddefaultcharset xxx が含まれています。xxx はエンコーディング名です。このコード行の意味: サーバー全体の Web ページ ファイルの https ヘッダーの文字セットをデフォルトの xxx 文字セットに設定します。この行があることは、各ファイルにヘッダー ("content-type: text/html; charset=xxx") を追加することと同じです。これで、メタ設定が utf-8 であるにもかかわらず、ブラウザが常に gb2312 を使用する理由が理解できました。 Webページにヘッダー("content-type:text/html; charset=xxx")がある場合、デフォルトの文字セットが設定した文字セットに変更されるので、この機能は常に役に立ちます。 adddefaultcharset xxx の前に「#」を追加し、この文をコメントアウトし、ページにヘッダー (「content-type...」) が含まれていない場合は、メタ タグが有効になります。 概要: 並べ替え
Web プログラマーの場合は、各ページにヘッダー ("content-type: text/html; charset=xxx") を追加して、ページがどのサーバーでも正しく表示され、移植性が高いことを確認してください。 adddefaultcharset xxx 文に関しては、コメントするかどうかは意見の問題です。とりあえずコメントアウトしましたが、ページを書くときにサーバー上で正常に表示されるようにheader()も書く必要があります。 2. データベースのエンコード データベースにクエリを実行する前に、php プログラムはまず mysql_query("set names xxxx"); を実行します。ここで、xxxx は Web ページのエンコーディング (charset=xxxx) の場合、xxxx=utf8 です。 Web ページの charset=gb2312 、次に xxxx=gb2312 です。ほとんどすべての Web プログラムには、データベースに接続するための共通のコードがあり、このファイルに mysql_query ("set names") を追加するだけです。 セット名は、クライアントによって送信された SQL ステートメントで使用されている文字セットを示します。したがって、set names 'utf-8' ステートメントはサーバーに、「このクライアントからの今後の情報では文字セット utf-8 が使用される」ことを伝えます。また、サーバーがクライアントに送り返す結果の文字セットも指定します。 (たとえば、select ステートメントを使用する場合、列の値にどの文字セットが使用されるかを示します。) PHPページの統一コーディング MySQL データベースのエンコーディング、HTML ページのエンコーディング、および PHP または HTML ファイル自体のエンコーディングはすべて一貫している必要があります。 1. MySQL データベースのエンコーディング: データベースの作成時にエンコーディング (gbk_chinese_ci など) を指定します。データ テーブルの作成、フィールドの作成、データの挿入時にエンコーディングを指定しないでください。データベースのエンコーディングは自動的に継承されます。 データベースに接続する場合は、データベースに接続した後に実行できるコーディングもあります。
2. HTML ページのエンコーディングは、次の行の設定を参照します。 3. phpまたはhtmlファイル自体のエンコード: editplus を使用して php ファイルまたは html ファイルを開き、保存するときにエンコードを選択します。データベースとページのエンコードが gbk の場合は、ここでエンコードとして ansi を選択します。 データベースとページのエンコードが utf-8 の場合、ここでも utf-8 が選択されます。 4. JavaScript または Flash で渡されるデータは UTF-8 でエンコードされているため、データベースとページのエンコードが GBK の場合は、トランスコードしてからデータベースに書き込む必要があることに注意してください。
5. PHP プログラムでは、PHP ソースのエンコーディングを指定する行を追加できます。プログラム:
|