uTools-Manuals/docs/php/openssl_seal.html
2019-04-08 23:22:26 +08:00

187 lines
8.9 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>密封 (加密) 数据</title>
</head>
<body class="docs"><div id="layout">
<div id="layout-content"><div id="function.openssl-seal" class="refentry">
<div class="refnamediv">
<h1 class="refname">openssl_seal</h1>
<p class="verinfo">(PHP 4 &gt;= 4.0.4, PHP 5, PHP 7)</p><p class="refpurpose"><span class="refname">openssl_seal</span> &mdash; <span class="dc-title">密封 (加密) 数据</span></p>
</div>
<div class="refsect1 description" id="refsect1-function.openssl-seal-description">
<h3 class="title">说明</h3>
<div class="methodsynopsis dc-description">
<span class="methodname"><strong>openssl_seal</strong></span>
( <span class="methodparam"><span class="type">string</span> <code class="parameter">$data</code></span>
, <span class="methodparam"><span class="type">string</span> <code class="parameter reference">&$sealed_data</code></span>
, <span class="methodparam"><span class="type">array</span> <code class="parameter reference">&$env_keys</code></span>
, <span class="methodparam"><span class="type">array</span> <code class="parameter">$pub_key_ids</code></span>
[, <span class="methodparam"><span class="type">string</span> <code class="parameter">$method</code><span class="initializer"> = &quot;RC4&quot;</span></span>
[, <span class="methodparam"><span class="type">string</span> <code class="parameter reference">&$iv</code></span>
]] ) : <span class="type">int</span></div>
<p class="para rdfs-comment">
<span class="function"><strong>openssl_seal()</strong></span> 使用随机生成的密钥和给定的 <code class="parameter">method</code> 方法密封 (加密)
<code class="parameter">data</code> 数据。 密钥用与<code class="parameter">pub_key_ids</code>中的标识符相关联的每个公共密钥加密,并且每个加密密钥在<code class="parameter">env_keys</code>中返回。 这意味着一个人可以将密封的数据发送给多个接收者(如果一个人已经获得了他们的公钥)。每个接收方都必须同时接收加密的数据和用接收方的公钥加密的信封密钥。
</p>
</div>
<div class="refsect1 parameters" id="refsect1-function.openssl-seal-parameters">
<h3 class="title">参数</h3>
<p class="para">
<dl>
<dt>
<code class="parameter">data</code></dt>
<dd>
<p class="para">
要密封的数据。
</p>
</dd>
<dt>
<code class="parameter">sealed_data</code></dt>
<dd>
<p class="para">
被密封后的数据。
</p>
</dd>
<dt>
<code class="parameter">env_keys</code></dt>
<dd>
<p class="para">
已被加密的密钥数组。
</p>
</dd>
<dt>
<code class="parameter">pub_key_ids</code></dt>
<dd>
<p class="para">
公钥资源标识符组成的数组。
</p>
</dd>
<dt>
<code class="parameter">method</code></dt>
<dd>
<p class="para">
加密算法。
</p>
</dd>
<dt>
<code class="parameter">iv</code></dt>
<dd>
<p class="para">
初始化向量。
</p>
</dd>
</dl>
</p>
</div>
<div class="refsect1 returnvalues" id="refsect1-function.openssl-seal-returnvalues">
<h3 class="title">返回值</h3>
<p class="para">
成功,返回密封后数据的长度,错误,返回 <strong><code>FALSE</code></strong> .
如果密封后的数据成功地通过<code class="parameter">sealed_data</code>变量返回,那么信封密钥也将会通过 <code class="parameter">env_keys</code> 变量返回。
</p>
</div>
<div class="refsect1 changelog" id="refsect1-function.openssl-seal-changelog">
<h3 class="title">更新日志</h3>
<table class="doctable informaltable">
<thead>
<tr>
<th>版本</th>
<th>说明</th>
</tr>
</thead>
<tbody class="tbody">
<tr>
<td>7.0.0</td>
<td>
添加 <code class="parameter">iv</code> 变量。
</td>
</tr>
<tr>
<td>5.3.0</td>
<td>
添加 <code class="parameter">method</code> 变量。
</td>
</tr>
</tbody>
</table>
</div>
<div class="refsect1 examples" id="refsect1-function.openssl-seal-examples">
<h3 class="title">范例</h3>
<p class="para">
<div class="example" id="example-944">
<p><strong>Example #1 <span class="function"><strong>openssl_seal()</strong></span> 范例:</strong></p>
<div class="example-contents">
<div class="phpcode"><pre><span style="color: #000000">
<span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">//&nbsp;$data&nbsp;is&nbsp;assumed&nbsp;to&nbsp;contain&nbsp;the&nbsp;data&nbsp;to&nbsp;be&nbsp;sealed<br /><br />//&nbsp;fetch&nbsp;public&nbsp;keys&nbsp;for&nbsp;our&nbsp;recipients,&nbsp;and&nbsp;ready&nbsp;them<br /></span><span style="color: #0000BB">$fp&nbsp;</span><span style="color: #007700">=&nbsp;</span><span style="color: #0000BB">fopen</span><span style="color: #007700">(</span><span style="color: #DD0000">"/src/openssl-0.9.6/demos/maurice/cert.pem"</span><span style="color: #007700">,&nbsp;</span><span style="color: #DD0000">"r"</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$cert&nbsp;</span><span style="color: #007700">=&nbsp;</span><span style="color: #0000BB">fread</span><span style="color: #007700">(</span><span style="color: #0000BB">$fp</span><span style="color: #007700">,&nbsp;</span><span style="color: #0000BB">8192</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">fclose</span><span style="color: #007700">(</span><span style="color: #0000BB">$fp</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$pk1&nbsp;</span><span style="color: #007700">=&nbsp;</span><span style="color: #0000BB">openssl_get_publickey</span><span style="color: #007700">(</span><span style="color: #0000BB">$cert</span><span style="color: #007700">);<br /></span><span style="color: #FF8000">//&nbsp;Repeat&nbsp;for&nbsp;second&nbsp;recipient<br /></span><span style="color: #0000BB">$fp&nbsp;</span><span style="color: #007700">=&nbsp;</span><span style="color: #0000BB">fopen</span><span style="color: #007700">(</span><span style="color: #DD0000">"/src/openssl-0.9.6/demos/sign/cert.pem"</span><span style="color: #007700">,&nbsp;</span><span style="color: #DD0000">"r"</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$cert&nbsp;</span><span style="color: #007700">=&nbsp;</span><span style="color: #0000BB">fread</span><span style="color: #007700">(</span><span style="color: #0000BB">$fp</span><span style="color: #007700">,&nbsp;</span><span style="color: #0000BB">8192</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">fclose</span><span style="color: #007700">(</span><span style="color: #0000BB">$fp</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$pk2&nbsp;</span><span style="color: #007700">=&nbsp;</span><span style="color: #0000BB">openssl_get_publickey</span><span style="color: #007700">(</span><span style="color: #0000BB">$cert</span><span style="color: #007700">);<br /><br /></span><span style="color: #FF8000">//&nbsp;seal&nbsp;message,&nbsp;only&nbsp;owners&nbsp;of&nbsp;$pk1&nbsp;and&nbsp;$pk2&nbsp;can&nbsp;decrypt&nbsp;$sealed&nbsp;with&nbsp;keys<br />//&nbsp;$ekeys[0]&nbsp;and&nbsp;$ekeys[1]&nbsp;respectively.<br /></span><span style="color: #0000BB">openssl_seal</span><span style="color: #007700">(</span><span style="color: #0000BB">$data</span><span style="color: #007700">,&nbsp;</span><span style="color: #0000BB">$sealed</span><span style="color: #007700">,&nbsp;</span><span style="color: #0000BB">$ekeys</span><span style="color: #007700">,&nbsp;array(</span><span style="color: #0000BB">$pk1</span><span style="color: #007700">,&nbsp;</span><span style="color: #0000BB">$pk2</span><span style="color: #007700">));<br /><br /></span><span style="color: #FF8000">//&nbsp;free&nbsp;the&nbsp;keys&nbsp;from&nbsp;memory<br /></span><span style="color: #0000BB">openssl_free_key</span><span style="color: #007700">(</span><span style="color: #0000BB">$pk1</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">openssl_free_key</span><span style="color: #007700">(</span><span style="color: #0000BB">$pk2</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span>
</span>
</pre></div>
</div>
</div>
</p>
</div>
<div class="refsect1 seealso" id="refsect1-function.openssl-seal-seealso">
<h3 class="title">参见</h3>
<p class="para">
<ul class="simplelist">
<li class="member"><span class="function"><a href="openssl_open.html" class="function" rel="rdfs-seeAlso">openssl_open()</a> - 打开密封的数据</span></li>
</ul>
</p>
</div>
</div></div></div></body></html>