<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.mcrypt.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'mcrypt.constants.php',
    1 => 'Предопределённые константы',
    2 => 'Предопределённые константы',
  ),
  'up' => 
  array (
    0 => 'book.mcrypt.php',
    1 => 'Mcrypt',
  ),
  'prev' => 
  array (
    0 => 'mcrypt.resources.php',
    1 => 'Типы ресурсов',
  ),
  'next' => 
  array (
    0 => 'mcrypt.ciphers.php',
    1 => 'Шифры Mcrypt',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/mcrypt/constants.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="mcrypt.constants" class="appendix">
 <h1 class="title">Предопределённые константы</h1>

 
<p class="simpara">
 Следующие константы определяются модулем
 и доступны, только если модуль либо собрали в PHP,
 либо динамически загрузили при выполнении кода.
</p>
 <p class="para">
  Mcrypt может работать в четырёх режимах блочного
  шифрования (<code class="literal">CBC</code>,
  <code class="literal">OFB</code>, <code class="literal">CFB</code> и
  <code class="literal">ECB</code>). Если слинковано с libmcrypt-2.4.x
  или выше, функции также могут работать в режимах
  <code class="literal">nOFB</code> и <code class="literal">STREAM</code>.
  Ниже вы найдёте список всех поддерживаемых режимов
  шифрования вместе с константами, которые определены
  для них.  Более подробно читайте
  Applied Cryptography by Schneier (ISBN 0-471-11709-9).
  <ul class="itemizedlist">
   <li class="listitem">
    <span class="simpara">
     <strong><code>MCRYPT_MODE_ECB</code></strong> (<code class="literal">electronic
     codebook</code>) - это режим блочного шифрования,
     который в целом непригоден для большинства задач.
     Использование этого режима не рекомендовано.
    </span>
   </li>
   <li class="listitem">
    <span class="simpara">
     <strong><code>MCRYPT_MODE_CBC</code></strong> (<code class="literal">cipher block
     chaining</code>) - это режим блочного шифрования,
     который немногим лучше <code class="literal">ECB</code>.
    </span>
   </li>
   <li class="listitem">
    <span class="simpara">
     <strong><code>MCRYPT_MODE_CFB</code></strong> (<code class="literal">cipher
     feedback, в 8-битном режиме</code>) - это режим
     потокового шифрования. Рекомендуется использовать
     режим <code class="literal">NCFB</code>, а не <code class="literal">CFB</code>.
    </span>
   </li>
   <li class="listitem">
    <span class="simpara">
     <strong><code>MCRYPT_MODE_OFB</code></strong> (<code class="literal">output feedback, в 8-битном режиме</code>)  - это
     режим потокового шифрования сравнимый с
     <code class="literal">CFB</code>, но может использоваться в
     приложениях, нетерпимых к распространению ошибок.
     Рекомендуется использовать режим
     <code class="literal">NOFB</code> вместо <code class="literal">OFB</code>.
    </span>
   </li>
   <li class="listitem">
    <span class="simpara">
     <strong><code>MCRYPT_MODE_NOFB</code></strong> (<code class="literal">output feedback,
     в N-битном режиме</code>) - сравним с режимом
     <code class="literal">OFB</code>, но оперирует полным размером
     блока алгоритма.
    </span>
   </li>
   <li class="listitem">
    <span class="simpara">
     <strong><code>MCRYPT_MODE_STREAM</code></strong> - это
     дополнительный режим для подключения некоторых
     потоковых алгоритмов, таких как
     <code class="literal">&quot;WAKE&quot;</code> или <code class="literal">&quot;RC4&quot;</code>.
    </span>
   </li>
  </ul>
 </p>

 <p class="para">
  Mcrypt поддерживает некоторые другие режимы работы
  для которых нет предопределённых констант. Их можно
  задавать с помощью строки вместо константы.
  <ul class="itemizedlist">
   <li class="listitem">
    <span class="simpara">
     <strong><code>"ctr"</code></strong> (<code class="literal">counter mode</code>) - режим потокового шифрования.
    </span>
   </li>
   <li class="listitem">
    <span class="simpara">
     <strong><code>"ncfb"</code></strong> (<code class="literal">cipher feedback,
     в N-битном режиме</code>)  - сравним с режимом
     <code class="literal">CFB</code>, но оперирует полным размером
     блока алгоритма.
    </span>
   </li>
  </ul>
 </p>

 <p class="para">
  Некоторые другие режимы и константы генераторов случайных чисел:
  <dl>
   
    <dt id="constant.mcrypt-encrypt">
     <strong><code><a href="mcrypt.constants.php#constant.mcrypt-encrypt">MCRYPT_ENCRYPT</a></code></strong>
     (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
    </dt>
    <dd>
     <span class="simpara">

     </span>
    </dd>
   
   
    <dt id="constant.mcrypt-decrypt">
     <strong><code><a href="mcrypt.constants.php#constant.mcrypt-decrypt">MCRYPT_DECRYPT</a></code></strong>
     (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
    </dt>
    <dd>
     <span class="simpara">

     </span>
    </dd>
   
   
    <dt id="constant.mcrypt-dev-random">
     <strong><code><a href="mcrypt.constants.php#constant.mcrypt-dev-random">MCRYPT_DEV_RANDOM</a></code></strong>
     (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
    </dt>
    <dd>
     <span class="simpara">

     </span>
    </dd>
   
   
    <dt id="constant.mcrypt-dev-urandom">
     <strong><code><a href="mcrypt.constants.php#constant.mcrypt-dev-urandom">MCRYPT_DEV_URANDOM</a></code></strong>
     (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
    </dt>
    <dd>
     <span class="simpara">

     </span>
    </dd>
   
   
    <dt id="constant.mcrypt-rand">
     <strong><code><a href="mcrypt.constants.php#constant.mcrypt-rand">MCRYPT_RAND</a></code></strong>
     (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
    </dt>
    <dd>
     <span class="simpara">

     </span>
    </dd>
   
  </dl>
 </p>
</div>
<?php manual_footer($setup); ?>