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

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

?? pubkey.h

?? 300個加解密的集合程序
?? H
字號:
#ifndef CRYPTOPP_PUBKEY_H
#define CRYPTOPP_PUBKEY_H

#include "cryptlib.h"
#include "misc.h"
#include <memory>
#include <assert.h>

NAMESPACE_BEGIN(CryptoPP)

class Integer;

class TrapdoorFunction
{
public:
	virtual ~TrapdoorFunction() {}

	virtual Integer ApplyFunction(const Integer &x) const =0;
	virtual Integer MaxPreimage() const =0;
	virtual Integer MaxImage() const =0;
};

class InvertableTrapdoorFunction : virtual public TrapdoorFunction
{
public:
	virtual Integer CalculateInverse(const Integer &x) const =0;
};

class PaddingScheme
{
public:
	virtual ~PaddingScheme() {}

	virtual unsigned int MaxUnpaddedLength(unsigned int paddedLength) const =0;

	virtual void Pad(RandomNumberGenerator &rng, const byte *raw, unsigned int inputLength, byte *padded, unsigned int paddedLength) const =0;
	// returns length of raw
	virtual unsigned int Unpad(const byte *padded, unsigned int paddedLength, byte *raw) const =0;
};

// ********************************************************

template <class H>
class MGF1
{
public:
	static void GenerateAndMask(byte *output, unsigned int outputLength, const byte *input, unsigned int inputLength);
};

template <class H>
void MGF1<H>::GenerateAndMask(byte *output, unsigned int outputLength, const byte *input, unsigned int inputLength)
{
	H h;
	SecByteBlock buf(STDMAX(4U, (unsigned int)H::DIGESTSIZE));
	word32 counter = 0;

	while (outputLength)
	{
		h.Update(input, inputLength);
		buf[0] = byte(counter >> 3*8);
		buf[1] = byte(counter >> 2*8);
		buf[2] = byte(counter >> 1*8);
		buf[3] = byte(counter);
		h.Update(buf, 4);
		h.Final(buf);

		unsigned int xorLen = STDMIN((unsigned int)H::DIGESTSIZE, outputLength);
		xorbuf(output, buf, xorLen);

		output += xorLen;
		outputLength -= xorLen;
		counter++;
	}
}

// ********************************************************

template <class F>
class PublicKeyBaseTemplate
{
public:
	PublicKeyBaseTemplate(const F &f) : f(f) {}
	PublicKeyBaseTemplate(BufferedTransformation &bt) : f(bt) {}
	void DEREncode(BufferedTransformation &bt) const {f.DEREncode(bt);}

	const F & GetTrapdoorFunction() const {return f;}

protected:
	// a hack to avoid having to write constructors for non-concrete derived classes
	PublicKeyBaseTemplate() : f(*(F*)0) {assert(false);}	// should never be called
	virtual unsigned int PaddedBlockBitLength() const =0;
	unsigned int PaddedBlockByteLength() const {return bitsToBytes(PaddedBlockBitLength());}

	F f;
};

// ********************************************************

template <class P, class F>
class CryptoSystemBaseTemplate : virtual public PK_FixedLengthCryptoSystem, virtual public PublicKeyBaseTemplate<F>
{
public:
	unsigned int MaxPlainTextLength() const;
	unsigned int CipherTextLength() const;

	P pad;

protected:
	CryptoSystemBaseTemplate() {}
	unsigned int PaddedBlockBitLength() const;
};

template <class P, class F>
class DecryptorTemplate : public PK_FixedLengthDecryptor, public CryptoSystemBaseTemplate<P, F>
{
public:
	~DecryptorTemplate() {}
	unsigned int Decrypt(const byte *cipherText, byte *plainText);

protected:
	DecryptorTemplate() {}
};

template <class P, class T>
class EncryptorTemplate : public PK_FixedLengthEncryptor, public CryptoSystemBaseTemplate<P, T>
{
public:
	~EncryptorTemplate() {}
	void Encrypt(RandomNumberGenerator &rng, const byte *plainText, unsigned int plainTextLength, byte *cipherText);

protected:
	EncryptorTemplate() {}
};

// ********************************************************

class DigestSignatureSystem
{
public:
	virtual ~DigestSignatureSystem() {};
	virtual unsigned int MaxDigestLength() const =0;
	virtual unsigned int DigestSignatureLength() const =0;
};

class DigestSigner : public virtual DigestSignatureSystem
{
public:
	virtual void SignDigest(RandomNumberGenerator &rng, const byte *digest, unsigned int digestLen, byte *signature) const =0;
};

class DigestVerifier : public virtual DigestSignatureSystem
{
public:
	virtual bool VerifyDigest(const byte *digest, unsigned int digestLen, const byte *sig) const =0;
};

template <class P, class T>
class DigestSignatureSystemBaseTemplate : virtual public DigestSignatureSystem, virtual public PublicKeyBaseTemplate<T>
{
public:
	unsigned int MaxDigestLength() const {return pad.MaxUnpaddedLength(PaddedBlockBitLength());}
	unsigned int DigestSignatureLength() const {return f.MaxPreimage().ByteCount();}

	P pad;

protected:
	DigestSignatureSystemBaseTemplate() {}
	unsigned int PaddedBlockBitLength() const {return f.MaxImage().BitCount()-1;}
};

template <class P, class T>
class DigestSignerTemplate : public DigestSigner, public DigestSignatureSystemBaseTemplate<P, T>
{
public:
	~DigestSignerTemplate() {}
	void SignDigest(RandomNumberGenerator &rng, const byte *message, unsigned int messageLength, byte *signature) const;

protected:
	DigestSignerTemplate() {}
};

template <class P, class T>
class DigestVerifierTemplate : public DigestVerifier, public DigestSignatureSystemBaseTemplate<P, T>
{
public:
	~DigestVerifierTemplate() {}
	bool VerifyDigest(const byte *digest, unsigned int digestLen, const byte *sig) const;

protected:
	DigestVerifierTemplate() {}
};

// ********************************************************

template <class S, class H>
class SignatureSystemBaseTemplate : virtual public PK_SignatureSystem, public S
{
public:
	unsigned int SignatureLength() const {return DigestSignatureLength();}
	HashModule * NewMessageAccumulator() const {return new H;}

protected:
	SignatureSystemBaseTemplate(const S &s) : S(s) {}
	SignatureSystemBaseTemplate(BufferedTransformation &bt) : S(bt) {}
	SignatureSystemBaseTemplate() {}
};

template <class S, class H>
class SignerTemplate : virtual public PK_Signer, public SignatureSystemBaseTemplate<S, H>
{
public:
	~SignerTemplate() {}
	void Sign(RandomNumberGenerator &rng, HashModule *messageAccumulator, byte *signature) const;

protected:
	SignerTemplate(const S &s) : SignatureSystemBaseTemplate<S, H>(s) {}
	SignerTemplate(BufferedTransformation &bt) : SignatureSystemBaseTemplate<S, H>(bt) {}
	SignerTemplate() {}
};

template <class S, class H>
class VerifierTemplate : virtual public PK_Verifier, public SignatureSystemBaseTemplate<S, H>
{
public:
	~VerifierTemplate() {}
	bool Verify(HashModule *messageAccumulator, const byte *sig) const;

protected:
	VerifierTemplate(const S &s) : SignatureSystemBaseTemplate<S, H>(s) {}
	VerifierTemplate(BufferedTransformation &bt) : SignatureSystemBaseTemplate<S, H>(bt) {}
	VerifierTemplate() {}
};

template <class S, class H>
void SignerTemplate<S,H>::Sign(RandomNumberGenerator &rng, HashModule *messageAccumulator, byte *signature) const
{
	std::auto_ptr<HashModule> ma(messageAccumulator);
	if (ma->DigestSize() > MaxDigestLength())
		throw KeyTooShort();
	SecByteBlock digest(ma->DigestSize());
	ma->Final(digest);
	SignDigest(rng, digest, digest.size, signature);
}

template <class S, class H>
bool VerifierTemplate<S,H>::Verify(HashModule *messageAccumulator, const byte *sig) const
{
	std::auto_ptr<HashModule> ma(messageAccumulator);
	SecByteBlock digest(ma->DigestSize());
	ma->Final(digest);
	return VerifyDigest(digest, digest.size, sig);
}

// ********************************************************

class SignatureEncodingMethodWithRecovery : public HashModule
{
public:
	void Final(byte *digest) {}
	virtual void Encode(RandomNumberGenerator &rng, byte *representative) =0;
	virtual bool Verify(const byte *representative) =0;
	virtual unsigned int Decode(byte *message) =0;
	virtual unsigned int MaximumRecoverableLength() const =0;
};

template <class F, class H>
class SignatureSystemWithRecoveryBaseTemplate : virtual public PK_SignatureSystemWithRecovery, virtual public PublicKeyBaseTemplate<F>
{
public:
	unsigned int SignatureLength() const {return f.MaxPreimage().ByteCount();}
	HashModule * NewMessageAccumulator() const {return new H(PaddedBlockBitLength());}
	unsigned int MaximumRecoverableLength() const {return H::MaximumRecoverableLength(PaddedBlockBitLength());}
	bool AllowLeftoverMessage() const {return H::AllowLeftoverMessage();}

protected:
	unsigned int PaddedBlockBitLength() const {return f.MaxImage().BitCount()-1;}
};

template <class F, class H>
class SignerWithRecoveryTemplate : virtual public PK_SignerWithRecovery, public SignatureSystemWithRecoveryBaseTemplate<F, H>
{
public:
	void Sign(RandomNumberGenerator &rng, HashModule *messageAccumulator, byte *signature) const;
};

template <class F, class H>
class VerifierWithRecoveryTemplate : virtual public PK_VerifierWithRecovery, public SignatureSystemWithRecoveryBaseTemplate<F, H>
{
public:
	bool Verify(HashModule *messageAccumulator, const byte *sig) const;
	HashModule * NewLeftoverMessageAccumulator(const byte *signature) const;
	unsigned int PartialRecover(HashModule *leftoverMessageAccumulator, byte *recoveredMessage) const;
	unsigned int Recover(const byte *signature, byte *recoveredMessage) const;
};

template <class F, class H>
void SignerWithRecoveryTemplate<F,H>::Sign(RandomNumberGenerator &rng, HashModule *messageAccumulator, byte *signature) const
{
	std::auto_ptr<H> ma(static_cast<H*>(messageAccumulator));
	if (ma->MaximumRecoverableLength() == 0)
		throw KeyTooShort();
	SecByteBlock representative(PaddedBlockByteLength());
	ma->Encode(rng, representative);
	f.CalculateInverse(Integer(representative, representative.size)).Encode(signature, SignatureLength());
}

template <class F, class H>
bool VerifierWithRecoveryTemplate<F,H>::Verify(HashModule *messageAccumulator, const byte *signature) const
{
	std::auto_ptr<H> ma(static_cast<H*>(messageAccumulator));
	SecByteBlock representative(PaddedBlockByteLength());
	f.ApplyFunction(Integer(signature, SignatureLength())).Encode(representative, representative.size);
	return ma->Verify(representative);
}

template <class F, class H>
HashModule * VerifierWithRecoveryTemplate<F,H>::NewLeftoverMessageAccumulator(const byte *signature) const
{
	SecByteBlock representative(PaddedBlockByteLength());
	f.ApplyFunction(Integer(signature, SignatureLength())).Encode(representative, representative.size);
	return new H(representative, PaddedBlockBitLength());
}

template <class F, class H>
unsigned int VerifierWithRecoveryTemplate<F,H>::PartialRecover(HashModule *messageAccumulator, byte *recoveredMessage) const
{
	std::auto_ptr<H> ma(static_cast<H*>(messageAccumulator));
	return ma->Decode(recoveredMessage);
}

template <class F, class H>
unsigned int VerifierWithRecoveryTemplate<F,H>::Recover(const byte *signature, byte *recoveredMessage) const
{
	return PartialRecover(NewLeftoverMessageAccumulator(signature), recoveredMessage);
}

NAMESPACE_END

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av亚洲精华国产精华精华| 香蕉成人伊视频在线观看| 欧美一级生活片| 欧美日韩五月天| 精品视频1区2区| 69成人精品免费视频| 91麻豆精品91久久久久久清纯| 欧美亚洲一区三区| 欧美视频一区二区三区四区| 欧美主播一区二区三区| 欧美日韩国产综合久久 | 精品久久免费看| 欧美不卡一区二区| 久久久久久免费| 国产精品久久二区二区| 亚洲同性gay激情无套| 亚洲一区二区三区小说| 青青青伊人色综合久久| 国产精品系列在线播放| 波多野结衣一区二区三区| 色综合久久99| 欧美顶级少妇做爰| 久久久久久久电影| 亚洲精品日韩一| 久久精品国产亚洲5555| 成人激情黄色小说| 欧美日本免费一区二区三区| 日韩午夜av一区| 国产精品国产馆在线真实露脸| 亚洲色图欧洲色图婷婷| 蜜臀av一区二区在线观看 | 91在线观看高清| 欧美一区二区私人影院日本| 久久美女高清视频| 亚洲韩国精品一区| 国产成人精品亚洲日本在线桃色 | 国产欧美一区二区在线| 亚洲免费资源在线播放| 久久精品免费看| 在线看国产一区| 久久久精品国产免大香伊| 亚洲一二三四久久| 成人国产精品免费观看| 9191久久久久久久久久久| 国产精品福利一区二区三区| 日本欧洲一区二区| 色av综合在线| 亚洲国产电影在线观看| 九九精品一区二区| 欧美精品vⅰdeose4hd| 亚洲视频电影在线| 韩国成人福利片在线播放| 欧美视频中文字幕| 亚洲私人影院在线观看| 国内精品嫩模私拍在线| 欧美三电影在线| 亚洲精品日韩综合观看成人91| 国产一区二区导航在线播放| 欧美肥妇free| 亚洲成精国产精品女| 97久久精品人人爽人人爽蜜臀 | 成人久久18免费网站麻豆 | 亚洲欧美在线高清| 国产成a人无v码亚洲福利| 日韩精品一区二区三区视频| 午夜精品久久久久久久| 91看片淫黄大片一级| 国产欧美精品区一区二区三区 | 日韩精品最新网址| 日韩黄色免费网站| 4438成人网| 午夜精品视频一区| 欧美丰满嫩嫩电影| 蜜臀av亚洲一区中文字幕| 精品日韩一区二区三区免费视频| 亚洲综合一区二区三区| 欧美日韩亚洲另类| 日韩福利视频网| 日韩欧美国产精品一区| 激情五月激情综合网| 久久精品视频在线看| 成人性生交大片免费看中文| 中文字幕乱码久久午夜不卡 | av在线播放成人| 综合色中文字幕| 欧美性极品少妇| 美女www一区二区| 久久久美女毛片| 99久久99久久精品免费观看| 亚洲欧美激情一区二区| 欧美在线观看一区二区| 日韩制服丝袜av| 26uuu国产电影一区二区| 国产成人免费视频精品含羞草妖精 | 本田岬高潮一区二区三区| 综合精品久久久| 欧美人妖巨大在线| 国产在线精品免费| 中文字幕一区二区三区四区| 欧美日韩综合在线免费观看| 精一区二区三区| 亚洲乱码日产精品bd| 日韩一区二区精品| 成人小视频在线| 日日夜夜免费精品| 欧美国产欧美亚州国产日韩mv天天看完整| 成人av手机在线观看| 五月婷婷久久综合| 中文字幕欧美激情| 91精品国产一区二区| av色综合久久天堂av综合| 亚洲成av人片一区二区梦乃 | 亚洲精品视频一区二区| 欧美一区二区三区成人| eeuss鲁片一区二区三区在线看| 国产一区亚洲一区| 中文av一区特黄| 91麻豆精品国产91久久久久| 成人激情av网| 九色综合国产一区二区三区| 亚洲精品久久7777| 国产亚洲精品福利| 欧美精品第一页| 91在线国产观看| 国内成人免费视频| 午夜精品视频一区| 亚洲免费在线视频一区 二区| 久久精品视频一区二区三区| 欧美日韩国产一级| 色婷婷综合激情| 国产夫妻精品视频| 久国产精品韩国三级视频| 一个色综合av| 亚洲免费av高清| |精品福利一区二区三区| 欧美变态口味重另类| 欧美精品v国产精品v日韩精品 | 蜜臀av一区二区在线观看| 亚洲第一在线综合网站| 一区二区在线看| 伊人婷婷欧美激情| 国产精品对白交换视频| 中文字幕国产一区| 国产夜色精品一区二区av| 亚洲精品一区二区三区香蕉 | a级高清视频欧美日韩| 国产精品系列在线播放| 国产一区欧美二区| 国产毛片精品一区| 国产精品一线二线三线精华| 国产在线精品免费av| 国模娜娜一区二区三区| 国产成人av自拍| 国产宾馆实践打屁股91| 成人亚洲精品久久久久软件| 成人午夜电影网站| 97aⅴ精品视频一二三区| 91视频一区二区三区| 91极品视觉盛宴| 555www色欧美视频| 日韩美女主播在线视频一区二区三区| 制服丝袜亚洲色图| 久久亚洲精品国产精品紫薇| 久久久久久久久久久久久夜| 中文字幕不卡的av| 亚洲精品视频免费观看| 水野朝阳av一区二区三区| 日本不卡一区二区三区| 国产一区二区精品久久| a亚洲天堂av| 欧美色电影在线| 精品电影一区二区三区| 亚洲国产精品v| 亚洲综合成人网| 精品中文字幕一区二区| 北条麻妃国产九九精品视频| 欧美性猛交xxxx乱大交退制版| 91精品国产aⅴ一区二区| 久久久综合视频| 亚洲综合色自拍一区| 另类小说综合欧美亚洲| 成人久久18免费网站麻豆 | 国产拍欧美日韩视频二区| **欧美大码日韩| 蜜臀久久久久久久| 国产成人丝袜美腿| 欧美日韩情趣电影| 国产亚洲精品中文字幕| 亚洲午夜精品久久久久久久久| 激情欧美一区二区| 一本久道中文字幕精品亚洲嫩| 日韩亚洲欧美综合| 日韩美女视频一区二区| 另类小说欧美激情| 欧美在线观看一区| 久久精品一区蜜桃臀影院| 亚洲国产精品一区二区久久恐怖片| 精品一区二区三区在线播放视频| 91亚洲精品久久久蜜桃| 欧美激情中文字幕|