PHPの文字化け対策
2014/07/03
PHPファイルもDBも全部UTF-8で出来たらいいけど、
そうもいかない場合が多いので文字化け対策。
-----
■headerでデータタイプを宣言する
header("Content-type: text/html charset=Shift_JIS");
-----
■mb_internal_encodingで内部コードを設定する。
mb_internal_encoding("UTF-8");
※引数なしだと現在の内部コードを表示できるとのこと。
echo mb_internal_encoding();
-----
■urlencodeでURLエンコード
echo '<a href="index.php?name=', urlencode($str),'">';
日本語をクエリで送る際とかに使用する。
文字コード変えて送ることも出来るが、
どうにもならない時はこれを試す。
-----
■mb_convert_encodingで文字コードを変換する
$str = mb_convert_encoding($str, "EUC-JP", "UTF-8");
これだとUTF-8からEUC-JPへの変換になる。
現在の文字コードをauto指定すると自動検出可能だが
厳密ではないらしい。
-----
■mb_detect_encodingで現在の文字コードを調べる
echo mb_detect_encoding($str);
これはあんまり厳密な判定じゃないらしい。
-----
■DB接続時にset namesを使う
mysql_query("SET NAMES ujis");
脆弱性があるらしい。
-----
■mysql_set_charsetで文字コード指定
mysql_set_charset('utf8');
PHP5.2.2以上で使えるとのこと。
会社のサーバーのPHPバージョンは未確認。
-----
以上。
関連記事
-
opauthのTwitterでログインできない際の対応方法
opauthを使ったソーシャルログインのシステムにてTwitterでログインでき ...
-
PHPでファイルをダウンロードさせる
集計ページみたいなんがあった。その集計ページを CSV化したいと言われた。 ■ソ ...
-
XHTMLをPHPファイルで取り扱う際の注意点
デザイナーさんからガラケーサイト用に渡されたHTMLファイルが XHTMLで書か ...
-
ディレクトリに設置してあるフォルダをPHPで調べて表示
やりたい事はsampleというディレクトリがあったとして、その直下にあるフォルダ ...
-
MySQLから任意の順番で取り出す
SELECT * FROM テーブル名 WHERE seq = $seq OR ...