gfpcrypt_8h-source.html

来自「Crypto++是一个非常强大的密码学库,主要是功能全」· HTML 代码 · 共 516 行 · 第 1/5 页

HTML
516
字号
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1"><title>Crypto++: gfpcrypt.h Source File</title><link href="doxygen.css" rel="stylesheet" type="text/css"></head><body><!-- Generated by Doxygen 1.3.2 --><div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="namespaces.html">Namespace List</a> | <a class="qindex" href="hierarchy.html">Class&nbsp;Hierarchy</a> | <a class="qindex" href="classes.html">Alphabetical&nbsp;List</a> | <a class="qindex" href="annotated.html">Compound&nbsp;List</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="namespacemembers.html">Namespace&nbsp;Members</a> | <a class="qindex" href="functions.html">Compound&nbsp;Members</a> | <a class="qindex" href="globals.html">File&nbsp;Members</a></div><h1>gfpcrypt.h</h1><a href="gfpcrypt_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre>00001 <span class="preprocessor">#ifndef CRYPTOPP_GFPCRYPT_H</span>00002 <span class="preprocessor"></span><span class="preprocessor">#define CRYPTOPP_GFPCRYPT_H</span>00003 <span class="preprocessor"></span><span class="comment"></span>00004 <span class="comment">/** \file</span>00005 <span class="comment">        Implementation of schemes based on DL over GF(p)</span>00006 <span class="comment">*/</span>00007 00008 <span class="preprocessor">#include "<a class="code" href="pubkey_8h.html">pubkey.h</a>"</span>00009 <span class="preprocessor">#include "modexppc.h"</span>00010 <span class="preprocessor">#include "sha.h"</span>00011 <span class="preprocessor">#include "algparam.h"</span>00012 <span class="preprocessor">#include "asn.h"</span>00013 <span class="preprocessor">#include "smartptr.h"</span>00014 <span class="preprocessor">#include "hmac.h"</span>00015 00016 <span class="preprocessor">#include &lt;limits.h&gt;</span>00017 00018 NAMESPACE_BEGIN(CryptoPP)00019 00020 CRYPTOPP_DLL_TEMPLATE_CLASS <a class="code" href="class_d_l___group_parameters.html">DL_GroupParameters&lt;Integer&gt;</a>;00021 <span class="comment"></span>00022 <span class="comment">//! .</span><a name="l00023"></a><a class="code" href="class_d_l___group_parameters___integer_based.html">00023</a> <span class="comment"></span><span class="keyword">class </span>CRYPTOPP_DLL DL_GroupParameters_IntegerBased : <span class="keyword">public</span> <a class="code" href="class_d_l___group_parameters.html">DL_GroupParameters</a>&lt;Integer&gt;, <span class="keyword">public</span> <a class="code" href="class_a_s_n1_crypto_material.html">ASN1CryptoMaterial</a>00024 {00025         <span class="keyword">typedef</span> DL_GroupParameters_IntegerBased <a class="code" href="class_d_l___group_parameters___integer_based.html">ThisClass</a>;00026         00027 <span class="keyword">public</span>:00028         <span class="keywordtype">void</span> Initialize(<span class="keyword">const</span> DL_GroupParameters_IntegerBased &amp;params)00029                 {Initialize(params.<a class="code" href="class_d_l___group_parameters___integer_based.html#_d_l___group_parameters_impl_3_01_mod_exp_precomputation_00_01_d_l___fixed_base_precomputation_impl_3_01typename_mod_exp_precomputation_1_1_element_01_4_00_01_d_l___group_parameters___integer_based_01_4a25">GetModulus</a>(), params.<a class="code" href="class_d_l___group_parameters___integer_based.html#_d_l___group_parameters_impl_3_01_mod_exp_precomputation_00_01_d_l___fixed_base_precomputation_impl_3_01typename_mod_exp_precomputation_1_1_element_01_4_00_01_d_l___group_parameters___integer_based_01_4a13">GetSubgroupOrder</a>(), params.<a class="code" href="class_d_l___group_parameters.html#_d_l___group_parametersa7">GetSubgroupGenerator</a>());}00030         <span class="keywordtype">void</span> Initialize(<a class="code" href="class_random_number_generator.html">RandomNumberGenerator</a> &amp;rng, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> pbits)00031                 {<a class="code" href="class_generatable_crypto_material.html#_x_t_r___d_ha27">GenerateRandom</a>(rng, MakeParameters(<span class="stringliteral">"ModulusSize"</span>, (<span class="keywordtype">int</span>)pbits));}00032         <span class="keywordtype">void</span> Initialize(<span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;p, <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;g)00033                 {SetModulusAndSubgroupGenerator(p, g); SetSubgroupOrder(ComputeGroupOrder(p)/2);}00034         <span class="keywordtype">void</span> Initialize(<span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;p, <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;q, <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;g)00035                 {SetModulusAndSubgroupGenerator(p, g); SetSubgroupOrder(q);}00036 00037         <span class="comment">// ASN1Object interface</span>00038         <span class="keywordtype">void</span> <a class="code" href="class_a_s_n1_object.html#_a_s_n1_objecta1">BERDecode</a>(<a class="code" href="class_buffered_transformation.html">BufferedTransformation</a> &amp;bt);00039         <span class="keywordtype">void</span> <a class="code" href="class_a_s_n1_object.html#_a_s_n1_objecta2">DEREncode</a>(<a class="code" href="class_buffered_transformation.html">BufferedTransformation</a> &amp;bt) <span class="keyword">const</span>;00040 00041         <span class="comment">// GeneratibleCryptoMaterial interface</span><span class="comment"></span>00042 <span class="comment">        /*! parameters: (ModulusSize, SubgroupOrderSize (optional)) */</span>00043         <span class="keywordtype">void</span> <a class="code" href="class_generatable_crypto_material.html#_x_t_r___d_ha27">GenerateRandom</a>(<a class="code" href="class_random_number_generator.html">RandomNumberGenerator</a> &amp;rng, <span class="keyword">const</span> <a class="code" href="class_name_value_pairs.html">NameValuePairs</a> &amp;alg);00044         <span class="keywordtype">bool</span> <a class="code" href="class_name_value_pairs.html#_x509_public_keya28">GetVoidValue</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *name, <span class="keyword">const</span> std::type_info &amp;valueType, <span class="keywordtype">void</span> *pValue) <span class="keyword">const</span>;00045         <span class="keywordtype">void</span> <a class="code" href="class_crypto_material.html#_x509_public_keya11">AssignFrom</a>(<span class="keyword">const</span> <a class="code" href="class_name_value_pairs.html">NameValuePairs</a> &amp;source);00046         00047         <span class="comment">// DL_GroupParameters</span>00048         <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp; GetSubgroupOrder()<span class="keyword"> const </span>{<span class="keywordflow">return</span> m_q;}00049         <a class="code" href="class_integer.html">Integer</a> GetGroupOrder()<span class="keyword"> const </span>{<span class="keywordflow">return</span> GetFieldType() == 1 ? GetModulus()-<a class="code" href="class_integer.html#_integerz37_11">Integer::One</a>() : GetModulus()+<a class="code" href="class_integer.html#_integerz37_11">Integer::One</a>();}00050         <span class="keywordtype">bool</span> ValidateGroup(<a class="code" href="class_random_number_generator.html">RandomNumberGenerator</a> &amp;rng, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> level) <span class="keyword">const</span>;00051         <span class="keywordtype">bool</span> ValidateElement(<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> level, <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;element, <span class="keyword">const</span> DL_FixedBasePrecomputation&lt;Integer&gt; *precomp) <span class="keyword">const</span>;00052         <span class="keywordtype">bool</span> FastSubgroupCheckAvailable()<span class="keyword"> const </span>{<span class="keywordflow">return</span> GetCofactor() == 2;}00053         <span class="keywordtype">void</span> EncodeElement(<span class="keywordtype">bool</span> reversible, <span class="keyword">const</span> Element &amp;element, byte *encoded)<span class="keyword"> const</span>00054 <span class="keyword">                </span>{element.Encode(encoded, GetModulus().ByteCount());}00055         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> GetEncodedElementSize(<span class="keywordtype">bool</span> reversible)<span class="keyword"> const </span>{<span class="keywordflow">return</span> GetModulus().ByteCount();}00056         <a class="code" href="class_integer.html">Integer</a> DecodeElement(<span class="keyword">const</span> byte *encoded, <span class="keywordtype">bool</span> checkForGroupMembership) <span class="keyword">const</span>;00057         <a class="code" href="class_integer.html">Integer</a> ConvertElementToInteger(<span class="keyword">const</span> Element &amp;element)<span class="keyword"> const</span>00058 <span class="keyword">                </span>{<span class="keywordflow">return</span> element;}00059         <a class="code" href="class_integer.html">Integer</a> GetMaxExponent() <span class="keyword">const</span>;00060 00061         <a class="code" href="class_o_i_d.html">OID</a> GetAlgorithmID() <span class="keyword">const</span>;00062 00063         <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp; GetModulus() <span class="keyword">const</span> =0;00064         <span class="keyword">virtual</span> <span class="keywordtype">void</span> SetModulusAndSubgroupGenerator(<span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;p, <span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;g) =0;00065 00066         <span class="keywordtype">void</span> SetSubgroupOrder(<span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;q)00067                 {m_q = q; ParametersChanged();}00068 00069 <span class="keyword">protected</span>:00070         <a class="code" href="class_integer.html">Integer</a> ComputeGroupOrder(<span class="keyword">const</span> <a class="code" href="class_integer.html">Integer</a> &amp;modulus)<span class="keyword"> const</span>00071 <span class="keyword">                </span>{<span class="keywordflow">return</span> modulus-(GetFieldType() == 1 ? 1 : -1);}00072 00073         <span class="comment">// GF(p) = 1, GF(p^2) = 2</span>00074         <span class="keyword">virtual</span> <span class="keywordtype">int</span> GetFieldType() <span class="keyword">const</span> =0;00075         <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> GetDefaultSubgroupOrderSize(<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> modulusSize) <span class="keyword">const</span>;00076 00077 <span class="keyword">private</span>:00078         <a class="code" href="class_integer.html">Integer</a> m_q;00079 };00080 <span class="comment"></span>00081 <span class="comment">//! .</span>00082 <span class="comment"></span><span class="keyword">template</span> &lt;<span class="keyword">class</span> GROUP_PRECOMP, <span class="keyword">class</span> BASE_PRECOMP = DL_FixedBasePrecomputationImpl&lt;CPP_TYPENAME GROUP_PRECOMP::Element&gt; &gt;<a name="l00083"></a><a class="code" href="class_d_l___group_parameters___integer_based_impl.html">00083</a> <span class="keyword">class </span><a class="code" href="class_d_l___group_parameters___integer_based_impl.html">DL_GroupParameters_IntegerBasedImpl</a> : <span class="keyword">public</span> <a class="code" href="class_d_l___group_parameters_impl.html">DL_GroupParametersImpl</a>&lt;GROUP_PRECOMP, BASE_PRECOMP, DL_GroupParameters_IntegerBased&gt;00084 {00085         <span class="keyword">typedef</span> <a class="code" href="class_d_l___group_parameters___integer_based_impl.html">DL_GroupParameters_IntegerBasedImpl&lt;GROUP_PRECOMP, BASE_PRECOMP&gt;</a> <a class="code" href="class_d_l___group_parameters___integer_based_impl.html">ThisClass</a>;00086 00087 <span class="keyword">public</span>:00088         <span class="keyword">typedef</span> <span class="keyword">typename</span> GROUP_PRECOMP::Element Element;00089 00090         <span class="comment">// GeneratibleCryptoMaterial interface</span><a name="l00091"></a><a class="code" href="class_d_l___group_parameters___integer_based_impl.html#_d_l___group_parameters___integer_based_impla0">00091</a>         <span class="keywordtype">bool</span> <a class="code" href="class_d_l___group_parameters___integer_based_impl.html#_d_l___group_parameters___integer_based_impla0">GetVoidValue</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *name, <span class="keyword">const</span> std::type_info &amp;valueType, <span class="keywordtype">void</span> *pValue)<span class="keyword"> const</span>00092 <span class="keyword">                </span>{<span class="keywordflow">return</span> GetValueHelper&lt;DL_GroupParameters_IntegerBased&gt;(<span class="keyword">this</span>, name, valueType, pValue).Assignable();}00093 <a name="l00094"></a><a class="code" href="class_d_l___group_parameters___integer_based_impl.html#_d_l___group_parameters___integer_based_impla1">00094</a>         <span class="keywordtype">void</span> <a class="code" href="class_d_l___group_parameters___integer_based_impl.html#_d_l___group_parameters___integer_based_impla1">AssignFrom</a>(<span class="keyword">const</span> <a class="code" href="class_name_value_pairs.html">NameValuePairs</a> &amp;source)00095                 {AssignFromHelper&lt;DL_GroupParameters_IntegerBased&gt;(<span class="keyword">this</span>, source);}00096 00097         <span class="comment">// DL_GroupParameters</span>

⌨️ 快捷键说明

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