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

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

?? gfpcrypt.cpp

?? 加密函數庫:包括多種加密解密算法,數字簽名,散列算法
?? CPP
字號:
// dsa.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "gfpcrypt.h"
#include "asn.h"
#include "oids.h"
#include "nbtheory.h"

NAMESPACE_BEGIN(CryptoPP)

void TestInstantiations_gfpcrypt()
{
	GDSA<SHA>::Signer test;
	GDSA<SHA>::Verifier test1;
	DSA::Signer test5(NullRNG(), 100);
	DSA::Signer test2(test5);
	NR<SHA>::Signer test3;
	NR<SHA>::Verifier test4;
	DLIES<>::Encryptor test6;
	DLIES<>::Decryptor test7;
}

void DL_GroupParameters_DSA::GenerateRandom(RandomNumberGenerator &rng, const NameValuePairs &alg)
{
	Integer p, q, g;

	if (alg.GetValue("Modulus", p) && alg.GetValue("SubgroupGenerator", g))
	{
		q = alg.GetValueWithDefault("SubgroupOrder", ComputeGroupOrder(p)/2);
	}
	else
	{
		int modulusSize = 1024;
		alg.GetIntValue("ModulusSize", modulusSize) || alg.GetIntValue("KeySize", modulusSize);

		if (!DSA::IsValidPrimeLength(modulusSize))
			throw InvalidArgument("DSA: not a valid prime length");

		SecByteBlock seed(SHA::DIGESTSIZE);
		Integer h;
		int c;

		do
		{
			rng.GenerateBlock(seed, SHA::DIGESTSIZE);
		} while (!DSA::GeneratePrimes(seed, SHA::DIGESTSIZE*8, c, p, modulusSize, q));

		do
		{
			h.Randomize(rng, 2, p-2);
			g = a_exp_b_mod_c(h, (p-1)/q, p);
		} while (g <= 1);
	}

	Initialize(p, q, g);
}

bool DL_GroupParameters_DSA::ValidateGroup(RandomNumberGenerator &rng, unsigned int level) const
{
	bool pass = DL_GroupParameters_GFP::ValidateGroup(rng, level);
	pass = pass && DSA::IsValidPrimeLength(GetModulus().BitCount());
	pass = pass && GetSubgroupOrder().BitCount() == 160;
	return pass;
}

void DL_SignatureMessageEncodingMethod_DSA::ComputeMessageRepresentative(RandomNumberGenerator &rng, 
	const byte *recoverableMessage, unsigned int recoverableMessageLength,
	HashTransformation &hash, HashIdentifier hashIdentifier, bool messageEmpty,
	byte *representative, unsigned int representativeBitLength) const
{
	assert(recoverableMessageLength == 0);
	assert(hashIdentifier.second == 0);
	const unsigned int representativeByteLength = BitsToBytes(representativeBitLength);
	const unsigned int digestSize = hash.DigestSize();
	const unsigned int paddingLength = SaturatingSubtract(representativeByteLength, digestSize);

	memset(representative, 0, paddingLength);
	hash.TruncatedFinal(representative+paddingLength, STDMIN(representativeByteLength, digestSize));

	if (digestSize*8 > representativeBitLength)
	{
		Integer h(representative, representativeByteLength);
		h >>= representativeByteLength*8 - representativeBitLength;
		h.Encode(representative, representativeByteLength);
	}
}

void DL_SignatureMessageEncodingMethod_NR::ComputeMessageRepresentative(RandomNumberGenerator &rng, 
	const byte *recoverableMessage, unsigned int recoverableMessageLength,
	HashTransformation &hash, HashIdentifier hashIdentifier, bool messageEmpty,
	byte *representative, unsigned int representativeBitLength) const
{
	assert(recoverableMessageLength == 0);
	assert(hashIdentifier.second == 0);
	const unsigned int representativeByteLength = BitsToBytes(representativeBitLength);
	const unsigned int digestSize = hash.DigestSize();
	const unsigned int paddingLength = SaturatingSubtract(representativeByteLength, digestSize);

	memset(representative, 0, paddingLength);
	hash.TruncatedFinal(representative+paddingLength, STDMIN(representativeByteLength, digestSize));

	if (digestSize*8 >= representativeBitLength)
	{
		Integer h(representative, representativeByteLength);
		h >>= representativeByteLength*8 - representativeBitLength + 1;
		h.Encode(representative, representativeByteLength);
	}
}

bool DL_GroupParameters_IntegerBased::ValidateGroup(RandomNumberGenerator &rng, unsigned int level) const
{
	const Integer &p = GetModulus(), &q = GetSubgroupOrder();

	bool pass = true;
	pass = pass && p > Integer::One() && p.IsOdd();
	pass = pass && q > Integer::One() && q.IsOdd();

	if (level >= 1)
		pass = pass && GetCofactor() > Integer::One() && GetGroupOrder() % q == Integer::Zero();
	if (level >= 2)
		pass = pass && VerifyPrime(rng, q, level-2) && VerifyPrime(rng, p, level-2);

	return pass;
}

bool DL_GroupParameters_IntegerBased::ValidateElement(unsigned int level, const Integer &g, const DL_FixedBasePrecomputation<Integer> *gpc) const
{
	const Integer &p = GetModulus(), &q = GetSubgroupOrder();

	bool pass = true;
	pass = pass && GetFieldType() == 1 ? g.IsPositive() : g.NotNegative();
	pass = pass && g < p && !IsIdentity(g);

	if (level >= 1)
	{
		if (gpc)
			pass = pass && gpc->Exponentiate(GetGroupPrecomputation(), Integer::One()) == g;
	}
	if (level >= 2)
	{
		if (GetFieldType() == 2)
			pass = pass && Jacobi(g*g-4, p)==-1;

		// verifying that Lucas((p+1)/2, w, p)==2 is omitted because it's too costly
		// and at most 1 bit is leaked if it's false
		bool fullValidate = (GetFieldType() == 2 && level >= 3) || !FastSubgroupCheckAvailable();

		if (fullValidate)
			pass = pass && IsIdentity(gpc ? gpc->Exponentiate(GetGroupPrecomputation(), q) : ExponentiateElement(g, q));
		else if (GetFieldType() == 1)
			pass = pass && Jacobi(g, p) == 1;
	}

	return pass;
}

void DL_GroupParameters_IntegerBased::GenerateRandom(RandomNumberGenerator &rng, const NameValuePairs &alg)
{
	Integer p, q, g;
	
	if (alg.GetValue("Modulus", p) && alg.GetValue("SubgroupGenerator", g))
	{
		q = alg.GetValueWithDefault("SubgroupOrder", ComputeGroupOrder(p)/2);
	}
	else
	{
		int modulusSize, subgroupOrderSize;

		if (!alg.GetIntValue("ModulusSize", modulusSize))
			modulusSize = alg.GetIntValueWithDefault("KeySize", 2048);

		if (!alg.GetIntValue("SubgroupOrderSize", subgroupOrderSize))
			subgroupOrderSize = GetDefaultSubgroupOrderSize(modulusSize);

		PrimeAndGenerator pg;
		pg.Generate(GetFieldType() == 1 ? 1 : -1, rng, modulusSize, subgroupOrderSize);
		p = pg.Prime();
		q = pg.SubPrime();
		g = pg.Generator();
	}

	Initialize(p, q, g);
}

Integer DL_GroupParameters_IntegerBased::DecodeElement(const byte *encoded, bool checkForGroupMembership) const
{
	Integer g(encoded, GetModulus().ByteCount());
	if (!ValidateElement(1, g, NULL))
		throw DL_BadElement();
	return g;
}

void DL_GroupParameters_IntegerBased::BERDecode(BufferedTransformation &bt)
{
	BERSequenceDecoder parameters(bt);
		Integer p(parameters);
		Integer q(parameters);
		Integer g;
		if (parameters.EndReached())
		{
			g = q;
			q = ComputeGroupOrder(p) / 2;
		}
		else
			g.BERDecode(parameters);
	parameters.MessageEnd();

	SetModulusAndSubgroupGenerator(p, g);
	SetSubgroupOrder(q);
}

void DL_GroupParameters_IntegerBased::DEREncode(BufferedTransformation &bt) const
{
	DERSequenceEncoder parameters(bt);
		GetModulus().DEREncode(parameters);
		m_q.DEREncode(parameters);
		GetSubgroupGenerator().DEREncode(parameters);
	parameters.MessageEnd();
}

bool DL_GroupParameters_IntegerBased::GetVoidValue(const char *name, const std::type_info &valueType, void *pValue) const
{
	return GetValueHelper<DL_GroupParameters<Element> >(this, name, valueType, pValue)
		CRYPTOPP_GET_FUNCTION_ENTRY(Modulus);
}

void DL_GroupParameters_IntegerBased::AssignFrom(const NameValuePairs &source)
{
	AssignFromHelper(this, source)
		CRYPTOPP_SET_FUNCTION_ENTRY2(Modulus, SubgroupGenerator)
		CRYPTOPP_SET_FUNCTION_ENTRY(SubgroupOrder)
		;
}

OID DL_GroupParameters_IntegerBased::GetAlgorithmID() const
{
	return ASN1::id_dsa();
}

void DL_GroupParameters_GFP::SimultaneousExponentiate(Element *results, const Element &base, const Integer *exponents, unsigned int exponentsCount) const
{
	ModularArithmetic ma(GetModulus());
	ma.SimultaneousExponentiate(results, base, exponents, exponentsCount);
}

DL_GroupParameters_GFP::Element DL_GroupParameters_GFP::MultiplyElements(const Element &a, const Element &b) const
{
	return a_times_b_mod_c(a, b, GetModulus());
}

DL_GroupParameters_GFP::Element DL_GroupParameters_GFP::CascadeExponentiate(const Element &element1, const Integer &exponent1, const Element &element2, const Integer &exponent2) const
{
	ModularArithmetic ma(GetModulus());
	return ma.CascadeExponentiate(element1, exponent1, element2, exponent2);
}

Integer DL_GroupParameters_IntegerBased::GetMaxExponent() const
{
	return STDMIN(GetSubgroupOrder()-1, Integer::Power2(2*DiscreteLogWorkFactor(GetFieldType()*GetModulus().BitCount())));
}

unsigned int DL_GroupParameters_IntegerBased::GetDefaultSubgroupOrderSize(unsigned int modulusSize) const
{
	return 2*DiscreteLogWorkFactor(GetFieldType()*modulusSize);
}

NAMESPACE_END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜在线一二页| 在线视频亚洲一区| 另类欧美日韩国产在线| 亚洲影院理伦片| 亚洲午夜精品17c| 亚洲成在人线在线播放| 亚洲第一综合色| 日韩电影在线观看网站| 蜜臀av一区二区| 国产综合色在线| 成人精品gif动图一区| 成人午夜免费视频| 91行情网站电视在线观看高清版| 在线视频国内自拍亚洲视频| 欧美日韩精品一区二区三区 | 日本一区二区在线不卡| 久久嫩草精品久久久久| 国产精品午夜春色av| 一区二区欧美国产| 麻豆国产精品777777在线| 国产综合久久久久影院| 成人久久视频在线观看| 欧美日韩不卡一区| 久久久精品黄色| 一区二区三区不卡在线观看| 日本成人在线不卡视频| 国产激情精品久久久第一区二区| 99久久精品一区| 欧美一级高清片| 国产精品免费视频观看| 婷婷久久综合九色综合伊人色| 精品一区二区成人精品| 色综合色狠狠天天综合色| 69堂成人精品免费视频| 国产精品美女久久久久av爽李琼| 亚洲一区在线视频观看| 国产一区二区在线免费观看| 在线观看亚洲精品| 中文字幕乱码日本亚洲一区二区 | 国产精品国产三级国产普通话蜜臀| 亚洲欧美日韩久久| 激情综合亚洲精品| 欧美日韩的一区二区| 亚洲三级电影网站| 国产激情视频一区二区三区欧美 | 亚洲精品中文字幕乱码三区| 美女精品一区二区| 色诱视频网站一区| 中文字幕不卡在线| 极品尤物av久久免费看| 欧美日韩国产免费| 亚洲精品乱码久久久久久黑人 | 国产成人自拍网| 欧美日产在线观看| 一区二区三区鲁丝不卡| 福利一区福利二区| 久久综合久色欧美综合狠狠| 日本欧美一区二区三区乱码| 色婷婷亚洲综合| 亚洲精品一二三| aaa亚洲精品一二三区| 国产亚洲制服色| 国产一区91精品张津瑜| 日韩欧美在线1卡| 视频一区免费在线观看| 欧美午夜寂寞影院| 亚洲国产欧美日韩另类综合| 日本高清不卡视频| 亚洲天堂av一区| 91视频com| 亚洲私人影院在线观看| 成人app在线观看| 国产精品久久三| 成人免费观看男女羞羞视频| 国产精品丝袜91| 99r精品视频| 亚洲精品欧美专区| 欧美性大战久久久久久久 | 日本一区二区三区久久久久久久久不| 毛片不卡一区二区| 日韩免费一区二区三区在线播放| 日韩精品色哟哟| 日韩一区二区三区视频在线| 捆绑调教一区二区三区| 久久奇米777| www.一区二区| 亚洲精选免费视频| 69堂国产成人免费视频| 激情成人综合网| 国产精品你懂的| 一本色道久久综合狠狠躁的推荐 | 国产三级精品三级| av高清久久久| 视频一区国产视频| 久久久久成人黄色影片| 成人免费电影视频| 亚洲一区二区三区四区在线| 日韩精品中文字幕在线不卡尤物| 国产精品伊人色| 亚洲午夜久久久久久久久电影院 | 白白色 亚洲乱淫| 亚洲成人av一区二区| 日韩美女一区二区三区四区| 成人深夜视频在线观看| 亚洲国产乱码最新视频| 久久综合久久综合九色| 欧美在线视频日韩| 国产在线视频一区二区三区| 亚洲精品视频在线| 精品国产免费久久| 一本色道久久综合亚洲91 | 国产喂奶挤奶一区二区三区| 欧美在线你懂的| 国产福利一区二区| 天堂精品中文字幕在线| 欧美国产日本韩| 日韩视频在线永久播放| 91麻豆国产香蕉久久精品| 日韩福利视频导航| 亚洲综合精品自拍| 中文字幕av不卡| 欧美一区二区视频网站| 99国产精品久| 成人黄色国产精品网站大全在线免费观看| 亚洲va欧美va人人爽| 国产精品美女久久久久高潮| 精品欧美一区二区久久| 精品视频免费看| 91看片淫黄大片一级在线观看| 精品亚洲成av人在线观看| 亚洲成av人片在线| 亚洲手机成人高清视频| 亚洲国产精华液网站w| 精品99一区二区三区| 欧美区视频在线观看| 欧美在线啊v一区| 91在线视频播放| 国产麻豆精品在线| 久久国产精品色婷婷| 人人精品人人爱| 午夜久久久久久久久| 亚洲一区二区三区中文字幕| 亚洲黄色av一区| 亚洲综合清纯丝袜自拍| 亚洲精品高清视频在线观看| 亚洲图片激情小说| 亚洲欧美一区二区三区久本道91 | 日韩美一区二区三区| 91精品国产色综合久久不卡电影| 欧美色图第一页| 欧美日韩精品免费观看视频| 欧美乱熟臀69xxxxxx| 欧美日韩亚洲国产综合| 欧美丰满一区二区免费视频| 欧美一区二区在线不卡| 欧美一区二区日韩| 日韩午夜在线观看| 日韩午夜在线播放| 久久综合九色综合久久久精品综合| 亚洲精品一区二区三区福利| 久久久综合视频| 国产精品视频观看| 亚洲精品乱码久久久久久久久| 亚洲电影一级黄| 久久99精品视频| 国产91综合网| 欧美影视一区在线| 欧美一区二区网站| 国产欧美综合色| 亚洲综合久久久久| 激情欧美一区二区三区在线观看| 从欧美一区二区三区| 色综合一区二区| 日韩视频在线你懂得| 国产日韩欧美在线一区| 最近日韩中文字幕| 石原莉奈在线亚洲二区| 经典三级在线一区| gogogo免费视频观看亚洲一| 欧美丝袜第三区| 久久一夜天堂av一区二区三区| 中文字幕在线不卡一区二区三区| 一区二区三区资源| 久久精品99国产精品日本| 不卡欧美aaaaa| 欧美一区二区成人| 中文字幕一区二区三区不卡在线 | 免费观看久久久4p| 不卡视频免费播放| 欧美一区二区三区日韩| 国产精品不卡在线观看| 蜜臀av一区二区在线免费观看| 成人福利在线看| 日韩午夜小视频| 艳妇臀荡乳欲伦亚洲一区| 国产美女精品在线| 欧美疯狂做受xxxx富婆| 亚洲精品久久久蜜桃| 国产精品一区三区| 日韩一区二区三区四区|