亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? elgamal.h

?? 加密函數庫:包括多種加密解密算法,數字簽名,散列算法
?? H
字號:
#ifndef CRYPTOPP_ELGAMAL_H
#define CRYPTOPP_ELGAMAL_H

#include "modexppc.h"
#include "dsa.h"

NAMESPACE_BEGIN(CryptoPP)

class ElGamalBase : public DL_KeyAgreementAlgorithm_DH<Integer, NoCofactorMultiplication>, 
					public DL_KeyDerivationAlgorithm<Integer>, 
					public DL_SymmetricEncryptionAlgorithm
{
public:
	void Derive(const DL_GroupParameters<Integer> &params, byte *derivedKey, unsigned int derivedLength, const Integer &agreedElement, const Integer &ephemeralPublicKey) const
	{
		agreedElement.Encode(derivedKey, derivedLength);
	}

	unsigned int GetSymmetricKeyLength(unsigned int plainTextLength) const
	{
		return GetGroupParameters().GetModulus().ByteCount();
	}

	unsigned int GetSymmetricCiphertextLength(unsigned int plainTextLength) const
	{
		unsigned int len = GetGroupParameters().GetModulus().ByteCount();
		if (plainTextLength <= GetMaxSymmetricPlaintextLength(len))
			return len;
		else
			return 0;
	}

	unsigned int GetMaxSymmetricPlaintextLength(unsigned int cipherTextLength) const
	{
		unsigned int len = GetGroupParameters().GetModulus().ByteCount();
		if (cipherTextLength == len)
			return STDMIN(255U, len-3);
		else
			return 0;
	}

	void SymmetricEncrypt(RandomNumberGenerator &rng, const byte *key, const byte *plainText, unsigned int plainTextLength, byte *cipherText) const
	{
		const Integer &p = GetGroupParameters().GetModulus();
		unsigned int modulusLen = p.ByteCount();

		SecByteBlock block(modulusLen-1);
		rng.GenerateBlock(block, modulusLen-2-plainTextLength);
		memcpy(block+modulusLen-2-plainTextLength, plainText, plainTextLength);
		block[modulusLen-2] = plainTextLength;

		a_times_b_mod_c(Integer(key, modulusLen), Integer(block, modulusLen-1), p).Encode(cipherText, modulusLen);
	}

	DecodingResult SymmetricDecrypt(const byte *key, const byte *cipherText, unsigned int cipherTextLength, byte *plainText) const
	{
		const Integer &p = GetGroupParameters().GetModulus();
		unsigned int modulusLen = p.ByteCount();

		if (cipherTextLength != modulusLen)
			return DecodingResult();

		Integer m = a_times_b_mod_c(Integer(cipherText, modulusLen), Integer(key, modulusLen).InverseMod(p), p);

		m.Encode(plainText, 1);
		unsigned int plainTextLength = plainText[0];
		if (plainTextLength > GetMaxSymmetricPlaintextLength(modulusLen))
			return DecodingResult();
		m >>= 8;
		m.Encode(plainText, plainTextLength);
		return DecodingResult(plainTextLength);
	}

	virtual const DL_GroupParameters_GFP & GetGroupParameters() const =0;
};

template <class BASE, class SCHEME_OPTIONS, class KEY>
class ElGamalObjectImpl : public DL_ObjectImplBase<BASE, SCHEME_OPTIONS, KEY>, public ElGamalBase
{
public:
	unsigned int FixedMaxPlaintextLength() const {return MaxPlaintextLength(FixedCiphertextLength());}
	unsigned int FixedCiphertextLength() const {return CiphertextLength(0);}

	const DL_GroupParameters_GFP & GetGroupParameters() const {return GetKey().GetGroupParameters();}

	DecodingResult FixedLengthDecrypt(RandomNumberGenerator &rng, const byte *cipherText, byte *plainText) const
		{return Decrypt(rng, cipherText, FixedCiphertextLength(), plainText);}

protected:
	const DL_KeyAgreementAlgorithm<Integer> & GetKeyAgreementAlgorithm() const {return *this;}
	const DL_KeyDerivationAlgorithm<Integer> & GetKeyDerivationAlgorithm() const {return *this;}
	const DL_SymmetricEncryptionAlgorithm & GetSymmetricEncryptionAlgorithm() const {return *this;}
};

struct ElGamalKeys
{
	typedef DL_CryptoKeys_GFP::GroupParameters GroupParameters;
	typedef DL_PrivateKey_GFP_OldFormat<DL_CryptoKeys_GFP::PrivateKey> PrivateKey;
	typedef DL_PublicKey_GFP_OldFormat<DL_CryptoKeys_GFP::PublicKey> PublicKey;
};

//! ElGamal encryption scheme with non-standard padding
struct ElGamal
{
	typedef DL_CryptoSchemeOptions<ElGamal, ElGamalKeys, int, int, int> SchemeOptions;

	static const char * StaticAlgorithmName() {return "ElgamalEnc/Crypto++Padding";}

	class EncryptorImpl : public ElGamalObjectImpl<DL_EncryptorBase<Integer, PK_FixedLengthEncryptor>,  SchemeOptions, SchemeOptions::PublicKey>, public PublicKeyCopier<SchemeOptions>
	{
	public:
		void CopyKeyInto(SchemeOptions::PublicKey &key) const
			{key = GetKey();}
	};

	class DecryptorImpl : public ElGamalObjectImpl<DL_DecryptorBase<Integer, PK_FixedLengthDecryptor>, SchemeOptions, SchemeOptions::PrivateKey>, public PrivateKeyCopier<SchemeOptions>
	{
	public:
		void CopyKeyInto(SchemeOptions::PublicKey &key) const
			{GetKey().MakePublicKey(key);}
		void CopyKeyInto(SchemeOptions::PrivateKey &key) const
			{key = GetKey();}
	};

	typedef SchemeOptions::GroupParameters GroupParameters;
	//! implements PK_Encryptor interface
	typedef PK_FinalTemplate<EncryptorImpl> Encryptor;
	//! implements PK_Decryptor interface
	typedef PK_FinalTemplate<DecryptorImpl> Decryptor;
};

typedef ElGamal::Encryptor ElGamalEncryptor;
typedef ElGamal::Decryptor ElGamalDecryptor;

NAMESPACE_END

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区中文字幕| 日日噜噜夜夜狠狠视频欧美人| 亚洲精品第1页| 激情综合网av| 欧美日韩黄视频| 亚洲免费看黄网站| 国产成人av一区二区| 欧美一区二区三区免费在线看| 国产精品美日韩| 国产精品亚洲综合一区在线观看| 欧美精品日日鲁夜夜添| 亚洲欧美电影一区二区| 成人午夜电影网站| www亚洲一区| 极品少妇xxxx偷拍精品少妇| av毛片久久久久**hd| 亚洲精品一线二线三线无人区| 午夜精品成人在线| 在线免费观看不卡av| 亚洲精品美腿丝袜| 99综合电影在线视频| 国产精品麻豆视频| 国产成人精品三级| 国产精品视频一二| 国产成人精品免费在线| 久久久久久久久蜜桃| 韩国av一区二区三区四区| 日韩欧美国产一二三区| 免费在线观看视频一区| 在线成人高清不卡| 秋霞影院一区二区| 精品国产乱码久久久久久蜜臀| 日日骚欧美日韩| 日韩欧美激情一区| 国内外精品视频| 国产午夜精品一区二区三区视频 | 欧美国产日韩一二三区| 国产又粗又猛又爽又黄91精品| 91精品在线免费| 久久精品久久综合| 26uuu成人网一区二区三区| 国产一区二区三区在线观看精品 | 国产成人在线视频播放| 久久久久久免费网| 成人免费视频一区二区| 日韩理论电影院| 欧美日韩在线一区二区| 日韩成人免费电影| 精品粉嫩超白一线天av| 国产精品自拍网站| 一区二区三区中文字幕在线观看| 欧美专区日韩专区| 另类小说视频一区二区| 国产视频视频一区| 色妹子一区二区| 青青草97国产精品免费观看 | 亚洲高清免费观看 | 精品一区二区三区在线观看国产| 欧美白人最猛性xxxxx69交| 福利一区在线观看| 亚洲第一福利视频在线| 日韩一区二区三区免费观看| 精品午夜一区二区三区在线观看| 国产精品久久久久影院亚瑟 | 91在线视频免费91| 蜜臀a∨国产成人精品| 日本一二三四高清不卡| 91福利国产精品| 极品少妇xxxx精品少妇偷拍| 亚洲精品自拍动漫在线| 精品免费一区二区三区| 日韩一区二区三区电影| 国产一区啦啦啦在线观看| 亚洲免费在线播放| 国产调教视频一区| 3d成人动漫网站| 99久久精品久久久久久清纯| 日产精品久久久久久久性色| 国产精品乱码妇女bbbb| 欧美福利电影网| 99国产欧美久久久精品| 理论电影国产精品| 一区二区三区精品| 国产精品色在线观看| 日韩一本二本av| 欧美性大战久久久| 成人精品鲁一区一区二区| 美女精品自拍一二三四| 亚洲第一二三四区| 亚洲色图欧美激情| 国产色产综合产在线视频| 欧美一区二区三区色| 欧美四级电影在线观看| 97久久超碰国产精品| 国产99久久久国产精品免费看| 日韩成人精品视频| 丝袜亚洲另类丝袜在线| 一区二区三区精品在线| 国产精品传媒入口麻豆| 国产欧美日韩三级| 2023国产精品| 欧美精品一区二区蜜臀亚洲| 日韩一区二区中文字幕| 欧美挠脚心视频网站| 欧美性欧美巨大黑白大战| 色综合中文字幕国产| 国产精品一区二区三区四区| 久久国产日韩欧美精品| 乱一区二区av| 精品一区二区三区的国产在线播放| 日韩专区欧美专区| 青青草成人在线观看| 亚洲成av人影院| 日韩av中文字幕一区二区| 日韩av不卡一区二区| 日韩av网站在线观看| 日韩在线卡一卡二| 另类人妖一区二区av| 国产在线一区二区综合免费视频| 狠狠色丁香久久婷婷综合_中 | 成人精品在线视频观看| 成人av电影在线网| 99国产一区二区三精品乱码| 色诱视频网站一区| 在线一区二区观看| 欧美日韩精品是欧美日韩精品| 91福利国产成人精品照片| 欧美日韩精品免费观看视频| 欧美日韩一本到| 精品嫩草影院久久| 欧美国产1区2区| 亚洲最快最全在线视频| 视频一区二区三区入口| 久久99深爱久久99精品| 国产成人精品aa毛片| 色婷婷综合久久久中文字幕| 欧美精品精品一区| 精品久久久久久久久久久院品网| 精品国一区二区三区| 国产欧美日韩在线看| 亚洲精品视频观看| 久久超碰97中文字幕| 成人午夜伦理影院| 欧美欧美欧美欧美| 日本一区二区三区电影| 亚洲国产你懂的| 国产一区二区在线免费观看| 97久久精品人人做人人爽| 欧美顶级少妇做爰| 亚洲国产精华液网站w| 亚洲一区二区欧美日韩| 久久成人免费网站| 色婷婷久久久久swag精品| 91精品国产91久久久久久一区二区| 久久亚洲精华国产精华液 | 国产精品高清亚洲| 亚洲成人午夜电影| 成人一区二区三区| 欧美精品777| 亚洲视频资源在线| 久久99精品一区二区三区| 一本大道av伊人久久综合| 精品久久久三级丝袜| 一区二区三区小说| 国产成人在线观看| 91精品国产手机| 一区二区三区高清在线| 国产99久久久国产精品免费看| 欧美久久高跟鞋激| 亚洲欧美日韩电影| 国产一区二区三区四区在线观看| 欧美日韩一区二区不卡| 自拍偷拍亚洲激情| 国产麻豆日韩欧美久久| 56国语精品自产拍在线观看| 亚洲视频图片小说| 不卡一二三区首页| 精品国产乱码久久久久久久| 亚洲mv在线观看| 欧美三级在线视频| 亚洲免费在线播放| www.欧美色图| 国产欧美一区二区三区在线看蜜臀| 日韩精品一卡二卡三卡四卡无卡| 一本一本久久a久久精品综合麻豆| 国产午夜精品一区二区三区四区| 奇米影视7777精品一区二区| 色噜噜偷拍精品综合在线| 最新日韩在线视频| av在线一区二区三区| 亚洲国产岛国毛片在线| 国产999精品久久久久久绿帽| 精品国产一区久久| 久久99国产精品免费| 欧美电视剧在线看免费| 久久国产精品一区二区| wwwwww.欧美系列| 国产美女娇喘av呻吟久久 | 91精品中文字幕一区二区三区| 亚洲午夜精品一区二区三区他趣|