📄 class_simple_key_agreement_domain.html
字号:
<td class="mdname" nowrap> <em>publicKey</em></td> </tr> <tr> <td></td> <td class="md">) </td> <td class="md" colspan="2"> const<code> [pure virtual]</code></td> </tr> </table> </td> </tr></table><table cellspacing=5 cellpadding=0 border=0> <tr> <td> </td> <td><p>generate public key <p><dl compact><dt><b>Precondition:</b></dt><dd>size of publicKey == <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina2">PublicKeyLength()</a> </dd></dl><p>Implemented in <a class="el" href="class_d_h___domain.html#_d_h___domaina11">DH_Domain< GROUP_PARAMETERS, COFACTOR_OPTION ></a>, <a class="el" href="class_d_l___simple_key_agreement_domain_base.html#_d_l___simple_key_agreement_domain_basea5">DL_SimpleKeyAgreementDomainBase< T ></a>, <a class="el" href="class_x_t_r___d_h.html#_x_t_r___d_ha12">XTR_DH</a>, and <a class="el" href="class_d_l___simple_key_agreement_domain_base.html#_d_l___simple_key_agreement_domain_basea5">DL_SimpleKeyAgreementDomainBase< GROUP_PARAMETERS::Element ></a>.<p>Referenced by <a class="el" href="dh2_8h-source.html#l00040">DH2::GenerateEphemeralPublicKey()</a>, <a class="el" href="cryptlib_8cpp-source.html#l00645">GenerateKeyPair()</a>, and <a class="el" href="dh2_8h-source.html#l00029">DH2::GenerateStaticPublicKey()</a>. </td> </tr></table><a name="_x_t_r___d_ha20" doxytag="SimpleKeyAgreementDomain::GenerateKeyPair"></a><p><table class="mdTable" width="100%" cellpadding="2" cellspacing="0"> <tr> <td class="mdRow"> <table cellpadding="0" cellspacing="0" border="0"> <tr> <td class="md" nowrap valign="top"> void SimpleKeyAgreementDomain::GenerateKeyPair </td> <td class="md" valign="top">( </td> <td class="md" nowrap valign="top"><a class="el" href="class_random_number_generator.html">RandomNumberGenerator</a> & </td> <td class="mdname" nowrap> <em>rng</em>, </td> </tr> <tr> <td></td> <td></td> <td class="md" nowrap>byte * </td> <td class="mdname" nowrap> <em>privateKey</em>, </td> </tr> <tr> <td></td> <td></td> <td class="md" nowrap>byte * </td> <td class="mdname" nowrap> <em>publicKey</em></td> </tr> <tr> <td></td> <td class="md">) </td> <td class="md" colspan="2"> const<code> [virtual]</code></td> </tr> </table> </td> </tr></table><table cellspacing=5 cellpadding=0 border=0> <tr> <td> </td> <td><p>generate private/public key pair <p><dl compact><dt><b>Note:</b></dt><dd>equivalent to calling <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina3">GeneratePrivateKey()</a> and then <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina4">GeneratePublicKey()</a> </dd></dl><p>Definition at line <a class="el" href="cryptlib_8cpp-source.html#l00645">645</a> of file <a class="el" href="cryptlib_8cpp-source.html">cryptlib.cpp</a>.<p>References <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina3">GeneratePrivateKey()</a>, and <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina4">GeneratePublicKey()</a>.<p>Referenced by <a class="el" href="dh2_8h-source.html#l00042">DH2::GenerateEphemeralKeyPair()</a>, and <a class="el" href="dh2_8h-source.html#l00031">DH2::GenerateStaticKeyPair()</a>. </td> </tr></table><a name="_simple_key_agreement_domaina6" doxytag="SimpleKeyAgreementDomain::Agree"></a><p><table class="mdTable" width="100%" cellpadding="2" cellspacing="0"> <tr> <td class="mdRow"> <table cellpadding="0" cellspacing="0" border="0"> <tr> <td class="md" nowrap valign="top"> virtual bool SimpleKeyAgreementDomain::Agree </td> <td class="md" valign="top">( </td> <td class="md" nowrap valign="top">byte * </td> <td class="mdname" nowrap> <em>agreedValue</em>, </td> </tr> <tr> <td></td> <td></td> <td class="md" nowrap>const byte * </td> <td class="mdname" nowrap> <em>privateKey</em>, </td> </tr> <tr> <td></td> <td></td> <td class="md" nowrap>const byte * </td> <td class="mdname" nowrap> <em>otherPublicKey</em>, </td> </tr> <tr> <td></td> <td></td> <td class="md" nowrap>bool </td> <td class="mdname" nowrap> <em>validateOtherPublicKey</em> = true</td> </tr> <tr> <td></td> <td class="md">) </td> <td class="md" colspan="2"> const<code> [pure virtual]</code></td> </tr> </table> </td> </tr></table><table cellspacing=5 cellpadding=0 border=0> <tr> <td> </td> <td><p>derive agreed value from your private key and couterparty's public key, return false in case of failure <p><dl compact><dt><b>Note:</b></dt><dd>If you have previously validated the public key, use validateOtherPublicKey=false to save time. /*! </dd></dl><dl compact><dt><b>Precondition:</b></dt><dd>size of agreedValue == <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina0">AgreedValueLength()</a> <p>length of privateKey == <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina1">PrivateKeyLength()</a> <p>length of otherPublicKey == <a class="el" href="class_simple_key_agreement_domain.html#_simple_key_agreement_domaina2">PublicKeyLength()</a></dd></dl><p>Implemented in <a class="el" href="class_d_l___simple_key_agreement_domain_base.html#_d_l___simple_key_agreement_domain_basea6">DL_SimpleKeyAgreementDomainBase< T ></a>, <a class="el" href="class_x_t_r___d_h.html#_x_t_r___d_ha13">XTR_DH</a>, and <a class="el" href="class_d_l___simple_key_agreement_domain_base.html#_d_l___simple_key_agreement_domain_basea6">DL_SimpleKeyAgreementDomainBase< GROUP_PARAMETERS::Element ></a>.<p>Referenced by <a class="el" href="dh2_8cpp-source.html#l00008">DH2::Agree()</a>. </td> </tr></table><hr>The documentation for this class was generated from the following files:<ul><li><a class="el" href="cryptlib_8h-source.html">cryptlib.h</a><li><a class="el" href="cryptlib_8cpp-source.html">cryptlib.cpp</a></ul><hr size="1"><address style="align: right;"><small>Generated on Tue Jul 8 23:35:34 2003 for Crypto++ by<a href="http://www.doxygen.org/index.html"><img src="doxygen.png" alt="doxygen" align="middle" border=0 > </a>1.3.2 </small></address></body></html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -