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

📄 modes.h

📁 lots Elliptic curve cryptography codes. Use Visual c++ to compile
💻 H
📖 第 1 页 / 共 2 页
字号:
	void ProcessLastBlock(byte *outString, const byte *inString, size_t length);	static const char * CRYPTOPP_API StaticAlgorithmName() {return "CBC/CTS";}protected:	void UncheckedSetKey(const byte *key, unsigned int length, const NameValuePairs &params)	{		CBC_Encryption::UncheckedSetKey(key, length, params);		m_stolenIV = params.GetValueWithDefault(Name::StolenIV(), (byte *)NULL);	}	byte *m_stolenIV;};class CRYPTOPP_DLL CRYPTOPP_NO_VTABLE CBC_Decryption : public CBC_ModeBase{public:	void ProcessData(byte *outString, const byte *inString, size_t length);	protected:	void ResizeBuffers()	{		BlockOrientedCipherModeBase::ResizeBuffers();		m_temp.New(BlockSize());	}	AlignedSecByteBlock m_temp;};class CRYPTOPP_DLL CRYPTOPP_NO_VTABLE CBC_CTS_Decryption : public CBC_Decryption{public:	unsigned int MinLastBlockSize() const {return BlockSize()+1;}	void ProcessLastBlock(byte *outString, const byte *inString, size_t length);};//! _template <class CIPHER, class BASE>class CipherModeFinalTemplate_CipherHolder : protected ObjectHolder<CIPHER>, public AlgorithmImpl<BASE, CipherModeFinalTemplate_CipherHolder<CIPHER, BASE> >{public:	CipherModeFinalTemplate_CipherHolder()	{		this->m_cipher = &this->m_object;		this->ResizeBuffers();	}	CipherModeFinalTemplate_CipherHolder(const byte *key, size_t length)	{		this->m_cipher = &this->m_object;		this->SetKey(key, length);	}	CipherModeFinalTemplate_CipherHolder(const byte *key, size_t length, const byte *iv)	{		this->m_cipher = &this->m_object;		this->SetKey(key, length, MakeParameters(Name::IV(), ConstByteArrayParameter(iv, this->m_cipher->BlockSize())));	}	CipherModeFinalTemplate_CipherHolder(const byte *key, size_t length, const byte *iv, int feedbackSize)	{		this->m_cipher = &this->m_object;		this->SetKey(key, length, MakeParameters(Name::IV(), ConstByteArrayParameter(iv, this->m_cipher->BlockSize()))(Name::FeedbackSize(), feedbackSize));	}	static std::string CRYPTOPP_API StaticAlgorithmName()		{return CIPHER::StaticAlgorithmName() + "/" + BASE::StaticAlgorithmName();}};//! _template <class BASE>class CipherModeFinalTemplate_ExternalCipher : public BASE{public:	CipherModeFinalTemplate_ExternalCipher() {}	CipherModeFinalTemplate_ExternalCipher(BlockCipher &cipher)		{this->SetCipher(cipher);}	CipherModeFinalTemplate_ExternalCipher(BlockCipher &cipher, const byte *iv, int feedbackSize = 0)		{this->SetCipherWithIV(cipher, iv, feedbackSize);}	std::string AlgorithmName() const		{return (this->m_cipher ? this->m_cipher->AlgorithmName() + "/" : std::string("")) + BASE::StaticAlgorithmName();}};CRYPTOPP_DLL_TEMPLATE_CLASS CFB_CipherTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> >;CRYPTOPP_DLL_TEMPLATE_CLASS CFB_EncryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> >;CRYPTOPP_DLL_TEMPLATE_CLASS CFB_DecryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> >;//! CFB modetemplate <class CIPHER>struct CFB_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ConcretePolicyHolder<Empty, CFB_EncryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > Encryption;	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ConcretePolicyHolder<Empty, CFB_DecryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > Decryption;};//! CFB mode, external cipherstruct CFB_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<ConcretePolicyHolder<Empty, CFB_EncryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > Encryption;	typedef CipherModeFinalTemplate_ExternalCipher<ConcretePolicyHolder<Empty, CFB_DecryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > Decryption;};//! CFB mode FIPS variant, requiring full block plaintext according to FIPS 800-38Atemplate <class CIPHER>struct CFB_FIPS_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ConcretePolicyHolder<Empty, CFB_RequireFullDataBlocks<CFB_EncryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > > Encryption;	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ConcretePolicyHolder<Empty, CFB_RequireFullDataBlocks<CFB_DecryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > > Decryption;};//! CFB mode FIPS variant, requiring full block plaintext according to FIPS 800-38A, external cipherstruct CFB_FIPS_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<ConcretePolicyHolder<Empty, CFB_RequireFullDataBlocks<CFB_EncryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > > Encryption;	typedef CipherModeFinalTemplate_ExternalCipher<ConcretePolicyHolder<Empty, CFB_RequireFullDataBlocks<CFB_DecryptionTemplate<AbstractPolicyHolder<CFB_CipherAbstractPolicy, CFB_ModePolicy> > > > > Decryption;};CRYPTOPP_DLL_TEMPLATE_CLASS AdditiveCipherTemplate<AbstractPolicyHolder<AdditiveCipherAbstractPolicy, OFB_ModePolicy> >;//! OFB modetemplate <class CIPHER>struct OFB_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ConcretePolicyHolder<Empty, AdditiveCipherTemplate<AbstractPolicyHolder<AdditiveCipherAbstractPolicy, OFB_ModePolicy> > > > Encryption;	typedef Encryption Decryption;};//! OFB mode, external cipherstruct OFB_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<ConcretePolicyHolder<Empty, AdditiveCipherTemplate<AbstractPolicyHolder<AdditiveCipherAbstractPolicy, OFB_ModePolicy> > > > Encryption;	typedef Encryption Decryption;};CRYPTOPP_DLL_TEMPLATE_CLASS AdditiveCipherTemplate<AbstractPolicyHolder<AdditiveCipherAbstractPolicy, CTR_ModePolicy> >;//! CTR modetemplate <class CIPHER>struct CTR_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ConcretePolicyHolder<Empty, AdditiveCipherTemplate<AbstractPolicyHolder<AdditiveCipherAbstractPolicy, CTR_ModePolicy> > > > Encryption;	typedef Encryption Decryption;};//! CTR mode, external cipherstruct CTR_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<ConcretePolicyHolder<Empty, AdditiveCipherTemplate<AbstractPolicyHolder<AdditiveCipherAbstractPolicy, CTR_ModePolicy> > > > Encryption;	typedef Encryption Decryption;};//! ECB modetemplate <class CIPHER>struct ECB_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, ECB_OneWay> Encryption;	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Decryption, ECB_OneWay> Decryption;};CRYPTOPP_DLL_TEMPLATE_CLASS CipherModeFinalTemplate_ExternalCipher<ECB_OneWay>;//! ECB mode, external cipherstruct ECB_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<ECB_OneWay> Encryption;	typedef Encryption Decryption;};//! CBC modetemplate <class CIPHER>struct CBC_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, CBC_Encryption> Encryption;	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Decryption, CBC_Decryption> Decryption;};CRYPTOPP_DLL_TEMPLATE_CLASS CipherModeFinalTemplate_ExternalCipher<CBC_Encryption>;CRYPTOPP_DLL_TEMPLATE_CLASS CipherModeFinalTemplate_ExternalCipher<CBC_Decryption>;//! CBC mode, external cipherstruct CBC_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<CBC_Encryption> Encryption;	typedef CipherModeFinalTemplate_ExternalCipher<CBC_Decryption> Decryption;};//! CBC mode with ciphertext stealingtemplate <class CIPHER>struct CBC_CTS_Mode : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Encryption, CBC_CTS_Encryption> Encryption;	typedef CipherModeFinalTemplate_CipherHolder<CPP_TYPENAME CIPHER::Decryption, CBC_CTS_Decryption> Decryption;};CRYPTOPP_DLL_TEMPLATE_CLASS CipherModeFinalTemplate_ExternalCipher<CBC_CTS_Encryption>;CRYPTOPP_DLL_TEMPLATE_CLASS CipherModeFinalTemplate_ExternalCipher<CBC_CTS_Decryption>;//! CBC mode with ciphertext stealing, external cipherstruct CBC_CTS_Mode_ExternalCipher : public CipherModeDocumentation{	typedef CipherModeFinalTemplate_ExternalCipher<CBC_CTS_Encryption> Encryption;	typedef CipherModeFinalTemplate_ExternalCipher<CBC_CTS_Decryption> Decryption;};#ifdef CRYPTOPP_MAINTAIN_BACKWARDS_COMPATIBILITYtypedef CFB_Mode_ExternalCipher::Encryption CFBEncryption;typedef CFB_Mode_ExternalCipher::Decryption CFBDecryption;typedef OFB_Mode_ExternalCipher::Encryption OFB;typedef CTR_Mode_ExternalCipher::Encryption CounterMode;#endifNAMESPACE_END#endif

⌨️ 快捷键说明

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