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

📄 modes_8cpp-source.html

📁 Crypto++是一个非常强大的密码学库,主要是功能全
💻 HTML
📖 第 1 页 / 共 2 页
字号:
<!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++: modes.cpp 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>modes.cpp</h1><div class="fragment"><pre>00001 <span class="comment">// modes.cpp - written and placed in the public domain by Wei Dai</span>00002 00003 <span class="preprocessor">#include "pch.h"</span>00004 00005 <span class="preprocessor">#ifndef CRYPTOPP_IMPORTS</span>00006 <span class="preprocessor"></span>00007 <span class="preprocessor">#include "<a class="code" href="modes_8h.html">modes.h</a>"</span>00008 00009 <span class="preprocessor">#ifndef NDEBUG</span>00010 <span class="preprocessor"></span><span class="preprocessor">#include "<a class="code" href="des_8h.html">des.h</a>"</span>00011 <span class="preprocessor">#endif</span>00012 <span class="preprocessor"></span>00013 NAMESPACE_BEGIN(CryptoPP)00014 00015 #ifndef NDEBUG00016 <span class="keywordtype">void</span> Modes_TestInstantiations()00017 {00018         <a class="code" href="struct_c_f_b___mode.html">CFB_Mode&lt;DES&gt;</a>::Encryption m0;00019         <a class="code" href="struct_c_f_b___mode.html">CFB_Mode&lt;DES&gt;</a>::Decryption m1;00020         <a class="code" href="struct_o_f_b___mode.html">OFB_Mode&lt;DES&gt;</a>::Encryption m2;00021         <a class="code" href="struct_c_t_r___mode.html">CTR_Mode&lt;DES&gt;</a>::Encryption m3;00022         <a class="code" href="struct_e_c_b___mode.html">ECB_Mode&lt;DES&gt;</a>::Encryption m4;00023         <a class="code" href="struct_c_b_c___mode.html">CBC_Mode&lt;DES&gt;</a>::Encryption m5;00024 }00025 <span class="preprocessor">#endif</span>00026 <span class="preprocessor"></span>00027 <span class="keywordtype">void</span> CipherModeBase::SetKey(<span class="keyword">const</span> byte *key, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> length, <span class="keyword">const</span> <a class="code" href="class_name_value_pairs.html">NameValuePairs</a> &amp;params)00028 {00029         UncheckedSetKey(params, key, length);   <span class="comment">// the underlying cipher will check the key length</span>00030 }00031 00032 <span class="keywordtype">void</span> CipherModeBase::GetNextIV(byte *IV)00033 {00034         <span class="keywordflow">if</span> (!<a class="code" href="class_stream_transformation.html#_symmetric_ciphera14">IsForwardTransformation</a>())00035                 <span class="keywordflow">throw</span> <a class="code" href="class_not_implemented.html">NotImplemented</a>(<span class="stringliteral">"CipherModeBase: GetNextIV() must be called on an encryption object"</span>);00036 00037         m_cipher-&gt;ProcessBlock(m_register);00038         memcpy(IV, m_register, <a class="code" href="namespace_name.html#a9">BlockSize</a>());00039 }00040 00041 <span class="keywordtype">void</span> CipherModeBase::SetIV(<span class="keyword">const</span> byte *iv)00042 {00043         <span class="keywordflow">if</span> (iv)00044                 <a class="code" href="class_simple_keying_interface.html#_x_m_a_c_ca33">Resynchronize</a>(iv);00045         <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="class_simple_keying_interface.html#_x_m_a_c_c___basea30">IsResynchronizable</a>())00046         {00047                 <span class="keywordflow">if</span> (!<a class="code" href="class_simple_keying_interface.html#_x_m_a_c_c___basea33">CanUseStructuredIVs</a>())00048                         <span class="keywordflow">throw</span> <a class="code" href="class_invalid_argument.html">InvalidArgument</a>(<span class="stringliteral">"CipherModeBase: this cipher mode cannot use a null IV"</span>);00049 00050                 <span class="comment">// use all zeros as default IV</span>00051                 <a class="code" href="class_sec_block.html">SecByteBlock</a> iv(<a class="code" href="namespace_name.html#a9">BlockSize</a>());00052                 memset(iv, 0, iv.<a class="code" href="class_sec_block.html#_sec_block_with_hinta13">size</a>());00053                 <a class="code" href="class_simple_keying_interface.html#_x_m_a_c_ca33">Resynchronize</a>(iv);00054         }00055 }00056 00057 <span class="keywordtype">void</span> CTR_ModePolicy::GetNextIV(byte *IV)00058 {00059         IncrementCounterByOne(IV, m_counterArray, <a class="code" href="namespace_name.html#a9">BlockSize</a>());00060 }00061 00062 <span class="keywordtype">void</span> CTR_ModePolicy::SeekToIteration(dword iterationCount)00063 {00064         <span class="keywordtype">int</span> carry=0;00065         <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i=<a class="code" href="namespace_name.html#a9">BlockSize</a>()-1; i&gt;=0 &amp;&amp; (iterationCount || carry); i--)00066         {00067                 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> sum = m_counterArray[i] + byte(iterationCount) + carry;00068                 m_counterArray[i] = (byte) sum;00069                 carry = sum &gt;&gt; 8;00070                 iterationCount &gt;&gt;= 8;00071         }00072 }00073 00074 <span class="keywordtype">void</span> CTR_ModePolicy::OperateKeystream(KeystreamOperation operation, byte *output, <span class="keyword">const</span> byte *input, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> iterationCount)00075 {00076         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxBlocks = m_cipher-&gt;OptimalNumberOfParallelBlocks();00077         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> sizeIncrement = maxBlocks * m_cipher-&gt;BlockSize();00078         <span class="keywordflow">while</span> (iterationCount &gt;= maxBlocks)00079         {00080                 ProcessMultipleBlocks(output, input, maxBlocks);00081                 output += sizeIncrement;00082                 input += sizeIncrement;00083                 iterationCount -= maxBlocks;00084         }00085         <span class="keywordflow">if</span> (iterationCount &gt; 0)00086                 ProcessMultipleBlocks(output, input, iterationCount);00087 }00088 <span class="keywordtype">void</span> CTR_ModePolicy::CipherResynchronize(byte *keystreamBuffer, <span class="keyword">const</span> byte *iv)00089 {00090         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> s = <a class="code" href="namespace_name.html#a9">BlockSize</a>();00091         memcpy(m_register, iv, s);00092         m_counterArray.New(s * m_cipher-&gt;OptimalNumberOfParallelBlocks());00093         memcpy(m_counterArray, iv, s);00094 }00095 00096 <span class="keywordtype">void</span> BlockOrientedCipherModeBase::UncheckedSetKey(<span class="keyword">const</span> <a class="code" href="class_name_value_pairs.html">NameValuePairs</a> &amp;params, <span class="keyword">const</span> byte *key, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> length)00097 {00098         m_cipher-&gt;SetKey(key, length, params);00099         ResizeBuffers();00100         <span class="keyword">const</span> byte *iv = params.<a class="code" href="class_name_value_pairs.html#_x_t_r___d_ha40">GetValueWithDefault</a>(Name::IV(), (<span class="keyword">const</span> byte *)NULL);00101         SetIV(iv);00102 }00103 00104 <span class="keywordtype">void</span> BlockOrientedCipherModeBase::ProcessData(byte *outString, <span class="keyword">const</span> byte *inString, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> length)00105 {00106         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> s = <a class="code" href="namespace_name.html#a9">BlockSize</a>();00107         assert(length % s == 0);00108         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> alignment = m_cipher-&gt;BlockAlignment();00109         <span class="keywordtype">bool</span> requireAlignedInput = RequireAlignedInput();00110 00111         <span class="keywordflow">if</span> (IsAlignedOn(outString, alignment))00112         {00113                 <span class="keywordflow">if</span> (!requireAlignedInput || IsAlignedOn(inString, alignment))00114                         ProcessBlocks(outString, inString, length / s);

⌨️ 快捷键说明

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