<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/openssl.constants.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'zh',
  ),
  'this' => 
  array (
    0 => 'openssl.pkcs7.flags.php',
    1 => 'PKCS7 flag/常量',
    2 => 'PKCS7 flag/常量',
  ),
  'up' => 
  array (
    0 => 'openssl.constants.php',
    1 => '预定义常量',
  ),
  'prev' => 
  array (
    0 => 'openssl.key-types.php',
    1 => '密钥类型',
  ),
  'next' => 
  array (
    0 => 'openssl.cms.flags.php',
    1 => 'CMS Flag/常量',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'zh',
    'path' => 'reference/openssl/constants.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="openssl.pkcs7.flags" class="section">
   <h2 class="title"><abbr>PKCS7</abbr> flag/常量</h2>
   <p class="para">
    S/MIME 函数使用通过一个位阈来表示的标志位，该位阈可包含如下一个或多个值：
    <table class="doctable table">
     <caption><strong><abbr>PKCS7</abbr> 常量</strong></caption>
      
       <thead>
        <tr>
         <th>常量名</th>
         <th>描述</th>
        </tr>

       </thead>

       <tbody class="tbody">
        <tr id="constant.pkcs7-text">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-text">PKCS7_TEXT</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>为加密/签名后的消息添加 <code class="literal">text/plain</code> 内容类型
         header。如果解密或者验证时，输出时会除去这些 header。如果解密或验证的消息不是
         <abbr title="Multipurpose Internet Mail Extensions">MIME</abbr> 类型 <code class="literal">text/plain</code>，则会发生错误。
         </td>
        </tr>

        <tr id="constant.pkcs7-binary">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-binary">PKCS7_BINARY</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>通常输入消息将被转成以 <code class="literal">CR</code> 和 <code class="literal">LF</code> 作行末的 &quot;canonical&quot; 格式(S/MIME规范中的声明)。当该选项出现时，消息将不会被转化。 当处理非 MIME 格式的二进制数据时，这个选项会很有用。</td>
        </tr>

        <tr id="constant.pkcs7-nointern">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-nointern">PKCS7_NOINTERN</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>在验证消息时，在消息中包含的证书(如果有的话)通常会被搜索签名证书。 对于该选项，只有当 <span class="function"><a href="function.openssl-pkcs7-verify.php" class="function">openssl_pkcs7_verify()</a></span> 函数的参数 <code class="parameter">untrusted_certificates_filename</code> 指定了的证书才会被使用。然而提供的证书仍然被当做不受信任的证书使用。</td>
        </tr>

        <tr id="constant.pkcs7-noverify">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-noverify">PKCS7_NOVERIFY</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>不要验证签名消息的签名者证书。</td>
        </tr>

        <tr id="constant.pkcs7-nochain">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-nochain">PKCS7_NOCHAIN</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>不要约束验证签名者证书：不要把签名消息中的证书当做不受信任的证书。</td>
        </tr>

        <tr id="constant.pkcs7-nocerts">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-nocerts">PKCS7_NOCERTS</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>在签署消息时，签名者的证书通常包括在内，但是有了这个选项后，就不需要包括证书了。这将会缩小被签名消息的大小，但是验证人在本地必须有可用的签名者证书副本(比如由 <span class="function"><a href="function.openssl-pkcs7-verify.php" class="function">openssl_pkcs7_verify()</a></span> 函数中的 <code class="parameter">untrusted_certificates_filename</code> 参数传递) 。
         </td>
        </tr>

        <tr id="constant.pkcs7-noattr">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-noattr">PKCS7_NOATTR</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>通常当消息被签名了，一些属性的集合将会包含在内，比如签名时间和支持的对称算法。使用该选项用来设置不包含这些属性。
         </td>
        </tr>

        <tr id="constant.pkcs7-detached">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-detached">PKCS7_DETACHED</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>
          当签名消息时，使用 MIME 类型(<code class="literal">&quot;multipart/signed&quot;</code>)的明文签名。
          如果你为 <span class="function"><a href="function.openssl-pkcs7-sign.php" class="function">openssl_pkcs7_sign()</a></span> 函数没有指定任何 <code class="parameter">flags</code>，这个将会是默认的值。
          如果你关闭这个选项，消息将使用不透明的签名来签名, 这将会使消息更能抵抗邮件中继的翻译，但是不支持 S/MIME 的邮件客户端将不能读取该消息。
         </td>
        </tr>

        <tr id="constant.pkcs7-nosigs">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-nosigs">PKCS7_NOSIGS</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>不要尝试在消息中验证签名</td>
        </tr>

        <tr id="constant.pkcs7-nooldmimetype">
         <td>
          <strong><code><a href="openssl.pkcs7.flags.php#constant.pkcs7-nooldmimetype">PKCS7_NOOLDMIMETYPE</a></code></strong>
          (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>)
         </td>
         <td>
          自 PHP 8.3.0 起可用。
          将 content-type 设置为 <code class="literal">application/pkcs7-mime</code>，而不是 <code class="literal">application/x-pkcs7-mime</code> 来加密消息。
         </td>
        </tr>

       </tbody>
      
     </table>

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