<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.mbstring.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'mbstring.php4.req.php',
    1 => 'PHP の文字エンコーディングに関する要件',
    2 => 'PHP の文字エンコーディングに関する要件',
  ),
  'up' => 
  array (
    0 => 'book.mbstring.php',
    1 => 'マルチバイト文字列',
  ),
  'prev' => 
  array (
    0 => 'mbstring.overload.php',
    1 => '関数のオーバーロード機能',
  ),
  'next' => 
  array (
    0 => 'ref.mbstring.php',
    1 => 'マルチバイト文字列 関数',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'reference/mbstring/encoding-requirements.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="mbstring.php4.req" class="chapter">
 <h1 class="title">PHP の文字エンコーディングに関する要件</h1>

 <p class="para">
  以下の型のエンコーディングが、PHP で安全に使用することができます。
  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     シングルバイトエンコーディングで、
     <ul class="itemizedlist">
      <li class="listitem">
       <span class="simpara">
        <code class="literal">00h</code> から <code class="literal">7fh</code> の範囲の文字に関して、
        ASCII 互換 (ISO646 互換) のマッピングを有する。
       </span>
      </li>
     </ul>
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     マルチバイトエンコーディングで、
     <ul class="itemizedlist">
      <li class="listitem">
       <span class="simpara">
        <code class="literal">00h</code> から <code class="literal">7fh</code> の範囲の文字では、
        ASCII 互換のマッピングを有する。
       </span>
      </li>
      <li class="listitem">
       <span class="simpara">
        ISO2022 エスケープシーケンスを使用しない。
       </span>
      </li>
      <li class="listitem">
       <span class="simpara">
        単一の文字を表す複数バイトのいずれにおいても
        <code class="literal">00h</code> から <code class="literal">7fh</code>
        の値を使用しない。
       </span>
      </li>
     </ul>  
    </p>
   </li>
  </ul>
 </p>
 <p class="para">
  PHP で動作しないと思われる文字エンコーディングの例を以下に示します。
  <div class="informalexample">
   <div class="example-contents">
<div class="annotation-interactive cdata"><pre>
JIS, SJIS, ISO-2022-JP, BIG-5
</pre></div>
   </div>

  </div>
 </p>
 <p class="para">
  これらのエンコーディングで書かれた PHP スクリプトは、
  特に符号化された文字列がスクリプトで記述子やリテラルに使用される場合には、
  動作しない可能性がありますが、入力される HTTP クエリに関して
  <code class="literal">mbstring</code> の透過的なエンコーディングフィルタを
  設定することでこれらのエンコーディングをほとんど使用しないようにすることができます。
 </p>
 <blockquote class="note"><p><strong class="note">注意</strong>: 
  <p class="para">
   SJIS, BIG5, CP936, CP949, GB18030 は、読者がパーサー/コンパイラ、
   文字エンコーディングと文字エンコーディングの問題点について精通していない限り
   内部エンコーディングとして使用するべきではありません。
  </p>
 </p></blockquote>
 <blockquote class="note"><p><strong class="note">注意</strong>: 
  <p class="para">
   PHP でデータベースに接続する場合、性能を向上させるためにデータベースと PHP
   の内部エンコーディングについて同じ文字エンコーディングを使用することを推奨します。
  </p>
  <p class="para">
   PostgreSQL を使用している場合、
   バックエンドの文字エンコーディングと異なる文字エンコーディングを使用することが可能です。
   詳細については、PostgreSQL のマニュアルを参照ください。
  </p>
 </p></blockquote>
</div>
<?php manual_footer($setup); ?>