⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gfpcrypt_8cpp-source.html

📁 著名的密码库Crypto++的文档 C++语言的杰作。程序员必备。
💻 HTML
📖 第 1 页 / 共 3 页
字号:
<a name="l00081"></a>00081         hash.<a class="code" href="class_hash_transformation.html#590ecda344aa0fb045abf42ec08823b2" title="truncated version of Final()">TruncatedFinal</a>(representative+paddingLength, STDMIN(representativeByteLength, digestSize));<a name="l00082"></a>00082 <a name="l00083"></a>00083         <span class="keywordflow">if</span> (digestSize*8 &gt; representativeBitLength)<a name="l00084"></a>00084         {<a name="l00085"></a>00085                 <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> h(representative, representativeByteLength);<a name="l00086"></a>00086                 h &gt;&gt;= representativeByteLength*8 - representativeBitLength;<a name="l00087"></a>00087                 h.<a class="code" href="class_integer.html#c12ea467de9a609b86ec03d8cb8837e4" title="encode in big-endian format">Encode</a>(representative, representativeByteLength);<a name="l00088"></a>00088         }<a name="l00089"></a>00089 }<a name="l00090"></a>00090 <a name="l00091"></a><a class="code" href="class_d_l___signature_message_encoding_method___n_r.html#6a4cf939444c8eea9e47c674f6db6797">00091</a> <span class="keywordtype">void</span> <a class="code" href="class_d_l___signature_message_encoding_method___n_r.html#6a4cf939444c8eea9e47c674f6db6797">DL_SignatureMessageEncodingMethod_NR::ComputeMessageRepresentative</a>(<a class="code" href="class_random_number_generator.html" title="interface for random number generators">RandomNumberGenerator</a> &amp;rng, <a name="l00092"></a>00092         <span class="keyword">const</span> byte *recoverableMessage, <span class="keywordtype">size_t</span> recoverableMessageLength,<a name="l00093"></a>00093         <a class="code" href="class_hash_transformation.html" title="interface for hash functions and data processing part of MACs">HashTransformation</a> &amp;hash, <a class="code" href="pubkey_8h.html#ef874ed3f2d212ac4629255c8ef86dd0">HashIdentifier</a> hashIdentifier, <span class="keywordtype">bool</span> messageEmpty,<a name="l00094"></a>00094         byte *representative, <span class="keywordtype">size_t</span> representativeBitLength)<span class="keyword"> const</span><a name="l00095"></a>00095 <span class="keyword"></span>{<a name="l00096"></a>00096         assert(recoverableMessageLength == 0);<a name="l00097"></a>00097         assert(hashIdentifier.second == 0);<a name="l00098"></a>00098         <span class="keyword">const</span> <span class="keywordtype">size_t</span> representativeByteLength = BitsToBytes(representativeBitLength);<a name="l00099"></a>00099         <span class="keyword">const</span> <span class="keywordtype">size_t</span> digestSize = hash.<a class="code" href="class_hash_transformation.html#41faf8b1293a6c72390cb0c8bd668097" title="size of the hash returned by Final()">DigestSize</a>();<a name="l00100"></a>00100         <span class="keyword">const</span> <span class="keywordtype">size_t</span> paddingLength = SaturatingSubtract(representativeByteLength, digestSize);<a name="l00101"></a>00101 <a name="l00102"></a>00102         memset(representative, 0, paddingLength);<a name="l00103"></a>00103         hash.<a class="code" href="class_hash_transformation.html#590ecda344aa0fb045abf42ec08823b2" title="truncated version of Final()">TruncatedFinal</a>(representative+paddingLength, STDMIN(representativeByteLength, digestSize));<a name="l00104"></a>00104 <a name="l00105"></a>00105         <span class="keywordflow">if</span> (digestSize*8 &gt;= representativeBitLength)<a name="l00106"></a>00106         {<a name="l00107"></a>00107                 <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> h(representative, representativeByteLength);<a name="l00108"></a>00108                 h &gt;&gt;= representativeByteLength*8 - representativeBitLength + 1;<a name="l00109"></a>00109                 h.<a class="code" href="class_integer.html#c12ea467de9a609b86ec03d8cb8837e4" title="encode in big-endian format">Encode</a>(representative, representativeByteLength);<a name="l00110"></a>00110         }<a name="l00111"></a>00111 }<a name="l00112"></a>00112 <a name="l00113"></a><a class="code" href="class_d_l___group_parameters___integer_based.html#be42dee24455ea7aac8edee78012cbad">00113</a> <span class="keywordtype">bool</span> <a class="code" href="class_d_l___group_parameters___integer_based.html#be42dee24455ea7aac8edee78012cbad">DL_GroupParameters_IntegerBased::ValidateGroup</a>(<a class="code" href="class_random_number_generator.html" title="interface for random number generators">RandomNumberGenerator</a> &amp;rng, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> level)<span class="keyword"> const</span><a name="l00114"></a>00114 <span class="keyword"></span>{<a name="l00115"></a>00115         <span class="keyword">const</span> <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> &amp;p = GetModulus(), &amp;q = <a class="code" href="class_d_l___group_parameters___integer_based.html#e6eb7fd2937f5eee9740d0db173f0475">GetSubgroupOrder</a>();<a name="l00116"></a>00116 <a name="l00117"></a>00117         <span class="keywordtype">bool</span> pass = <span class="keyword">true</span>;<a name="l00118"></a>00118         pass = pass &amp;&amp; p &gt; <a class="code" href="class_integer.html#8c070592581bf6c2f928c72bfa1c1638" title="avoid calling constructors for these frequently used integers">Integer::One</a>() &amp;&amp; p.<a class="code" href="class_integer.html#ed4bb7208a18b986ef3e1a7d92e06d1d">IsOdd</a>();<a name="l00119"></a>00119         pass = pass &amp;&amp; q &gt; <a class="code" href="class_integer.html#8c070592581bf6c2f928c72bfa1c1638" title="avoid calling constructors for these frequently used integers">Integer::One</a>() &amp;&amp; q.<a class="code" href="class_integer.html#ed4bb7208a18b986ef3e1a7d92e06d1d">IsOdd</a>();<a name="l00120"></a>00120 <a name="l00121"></a>00121         <span class="keywordflow">if</span> (level &gt;= 1)<a name="l00122"></a>00122                 pass = pass &amp;&amp; <a class="code" href="class_d_l___group_parameters.html#1a7a2e50499872d2be408aa36621bf91">GetCofactor</a>() &gt; <a class="code" href="class_integer.html#8c070592581bf6c2f928c72bfa1c1638" title="avoid calling constructors for these frequently used integers">Integer::One</a>() &amp;&amp; <a class="code" href="class_d_l___group_parameters___integer_based.html#2aa2e513e93ac6110fafa7c26fd6dcd3">GetGroupOrder</a>() % q == <a class="code" href="class_integer.html#19b7e6d48b1b57bd4846160ea2928175" title="avoid calling constructors for these frequently used integers">Integer::Zero</a>();<a name="l00123"></a>00123         <span class="keywordflow">if</span> (level &gt;= 2)<a name="l00124"></a>00124                 pass = pass &amp;&amp; VerifyPrime(rng, q, level-2) &amp;&amp; VerifyPrime(rng, p, level-2);<a name="l00125"></a>00125 <a name="l00126"></a>00126         <span class="keywordflow">return</span> pass;<a name="l00127"></a>00127 }<a name="l00128"></a>00128 <a name="l00129"></a><a class="code" href="class_d_l___group_parameters___integer_based.html#dce1f61e6d7556ecebdac14f0018adbf">00129</a> <span class="keywordtype">bool</span> <a class="code" href="class_d_l___group_parameters___integer_based.html#dce1f61e6d7556ecebdac14f0018adbf">DL_GroupParameters_IntegerBased::ValidateElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> level, <span class="keyword">const</span> <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> &amp;g, <span class="keyword">const</span> <a class="code" href="class_d_l___fixed_base_precomputation.html">DL_FixedBasePrecomputation&lt;Integer&gt;</a> *gpc)<span class="keyword"> const</span><a name="l00130"></a>00130 <span class="keyword"></span>{<a name="l00131"></a>00131         <span class="keyword">const</span> <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> &amp;p = GetModulus(), &amp;q = <a class="code" href="class_d_l___group_parameters___integer_based.html#e6eb7fd2937f5eee9740d0db173f0475">GetSubgroupOrder</a>();<a name="l00132"></a>00132 <a name="l00133"></a>00133         <span class="keywordtype">bool</span> pass = <span class="keyword">true</span>;<a name="l00134"></a>00134         pass = pass &amp;&amp; GetFieldType() == 1 ? g.<a class="code" href="class_integer.html#13ddbfd8e9729932c2a99b0dff530978">IsPositive</a>() : g.<a class="code" href="class_integer.html#880ab53116f2b9f527489d86ee806896">NotNegative</a>();<a name="l00135"></a>00135         pass = pass &amp;&amp; g &lt; p &amp;&amp; !IsIdentity(g);<a name="l00136"></a>00136 <a name="l00137"></a>00137         <span class="keywordflow">if</span> (level &gt;= 1)<a name="l00138"></a>00138         {<a name="l00139"></a>00139                 <span class="keywordflow">if</span> (gpc)<a name="l00140"></a>00140                         pass = pass &amp;&amp; gpc-&gt;<a class="code" href="class_d_l___fixed_base_precomputation.html#c11f5d82936a1e62395230aba2a34ae4">Exponentiate</a>(GetGroupPrecomputation(), <a class="code" href="class_integer.html#8c070592581bf6c2f928c72bfa1c1638" title="avoid calling constructors for these frequently used integers">Integer::One</a>()) == g;<a name="l00141"></a>00141         }<a name="l00142"></a>00142         <span class="keywordflow">if</span> (level &gt;= 2)<a name="l00143"></a>00143         {<a name="l00144"></a>00144                 <span class="keywordflow">if</span> (GetFieldType() == 2)<a name="l00145"></a>00145                         pass = pass &amp;&amp; Jacobi(g*g-4, p)==-1;<a name="l00146"></a>00146 <a name="l00147"></a>00147                 <span class="comment">// verifying that Lucas((p+1)/2, w, p)==2 is omitted because it's too costly</span><a name="l00148"></a>00148                 <span class="comment">// and at most 1 bit is leaked if it's false</span><a name="l00149"></a>00149                 <span class="keywordtype">bool</span> fullValidate = (GetFieldType() == 2 &amp;&amp; level &gt;= 3) || !<a class="code" href="class_d_l___group_parameters___integer_based.html#c1cec62d442856c46c536e2ae1e0328a">FastSubgroupCheckAvailable</a>();<a name="l00150"></a>00150 <a name="l00151"></a>00151                 <span class="keywordflow">if</span> (fullValidate &amp;&amp; pass)<a name="l00152"></a>00152                 {<a name="l00153"></a>00153                         <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> gp = gpc ? gpc-&gt;<a class="code" href="class_d_l___fixed_base_precomputation.html#c11f5d82936a1e62395230aba2a34ae4">Exponentiate</a>(GetGroupPrecomputation(), q) : <a class="code" href="class_d_l___group_parameters.html#0b49c5d4dbe0b8de7b967d5c6c78e712">ExponentiateElement</a>(g, q);<a name="l00154"></a>00154                         pass = pass &amp;&amp; IsIdentity(gp);<a name="l00155"></a>00155                 }<a name="l00156"></a>00156                 <span class="keywordflow">else</span> <span class="keywordflow">if</span> (GetFieldType() == 1)<a name="l00157"></a>00157                         pass = pass &amp;&amp; Jacobi(g, p) == 1;<a name="l00158"></a>00158         }<a name="l00159"></a>00159 <a name="l00160"></a>00160         <span class="keywordflow">return</span> pass;<a name="l00161"></a>00161 }<a name="l00162"></a>00162 <a name="l00163"></a><a class="code" href="class_d_l___group_parameters___integer_based.html#8c9a79c493a215ca37408bb7ddfb5533">00163</a> <span class="keywordtype">void</span> <a class="code" href="class_d_l___group_parameters___integer_based.html#8c9a79c493a215ca37408bb7ddfb5533">DL_GroupParameters_IntegerBased::GenerateRandom</a>(<a class="code" href="class_random_number_generator.html" title="interface for random number generators">RandomNumberGenerator</a> &amp;rng, <span class="keyword">const</span> <a class="code" href="class_name_value_pairs.html" title="interface for retrieving values given their names">NameValuePairs</a> &amp;alg)<a name="l00164"></a>00164 {<a name="l00165"></a>00165         <a class="code" href="class_integer.html" title="multiple precision integer and basic arithmetics">Integer</a> p, q, g;<a name="l00166"></a>00166         <a name="l00167"></a>00167         <span class="keywordflow">if</span> (alg.<a class="code" href="class_name_value_pairs.html#96686e9f8d6ce3ab870e516fb72b608e" title="get a named value, returns true if the name exists">GetValue</a>(<span class="stringliteral">"Modulus"</span>, p) &amp;&amp; alg.<a class="code" href="class_name_value_pairs.html#96686e9f8d6ce3ab870e516fb72b608e" title="get a named value, returns true if the name exists">GetValue</a>(<span class="stringliteral">"SubgroupGenerator"</span>, g))<a name="l00168"></a>00168         {<a name="l00169"></a>00169                 q = alg.<a class="code" href="class_name_value_pairs.html#943b2009297783f1c35bae46efc3b5f7" title="get a named value, returns the default if the name doesn't exist">GetValueWithDefault</a>(<span class="stringliteral">"SubgroupOrder"</span>, <a class="code" href="class_d_l___group_parameters___integer_based.html#05c2b65749d0357845599a7d434e3903">ComputeGroupOrder</a>(p)/2);<a name="l00170"></a>00170         }<a name="l00171"></a>00171         <span class="keywordflow">else</span><a name="l00172"></a>00172         {<a name="l00173"></a>00173                 <span class="keywordtype">int</span> modulusSize, subgroupOrderSize;<a name="l00174"></a>00174 <a name="l00175"></a>00175                 <span class="keywordflow">if</span> (!alg.<a class="code" href="class_name_value_pairs.html#39b6daefcabcdd07f5ae482a075e1728" title="get a named value with type int">GetIntValue</a>(<span class="stringliteral">"ModulusSize"</span>, modulusSize))<a name="l00176"></a>00176                         modulusSize = alg.<a class="code" href="class_name_value_pairs.html#7ddb654b7afcd1a04422a7b4b01366d9" title="get a named value with type int, with default">GetIntValueWithDefault</a>(<span class="stringliteral">"KeySize"</span>, 2048);<a name="l00177"></a>00177 <a name="l00178"></a>00178                 <span class="keywordflow">if</span> (!alg.<a class="code" href="class_name_value_pairs.html#39b6daefcabcdd07f5ae482a075e1728" title="get a named value with type int">GetIntValue</a>(<span class="stringliteral">"SubgroupOrderSize"</span>, subgroupOrderSize))<a name="l00179"></a>00179                         subgroupOrderSize = <a class="code" href="class_d_l___group_parameters___integer_based.html#91dcd7ec2cad65152b863522144351bd">GetDefaultSubgroupOrderSize</a>(modulusSize);<a name="l00180"></a>00180 <a name="l00181"></a>00181                 <a class="code" href="class_prime_and_generator.html" title="generator of prime numbers of special forms">PrimeAndGenerator</a> pg;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -