CryptoPP的 AutoSeededX917RNG算法的使用

AutoSeededX917RNG算法是CryptoPP密码学库提供的又一系列随机数发生器,为什么说其是“一系列”而不是“一个”算法。从CryptoPP的源代码和帮助文档中可以看到,AutoSeededX917RNG是一个类模板,它的类型参数可以是任何的分组密码算法。因此,可以将AutoSeededX917RNG和Cryptopp中的任何分组密码进行组合,就可以产生一种新的随机数发生器。

AutoSeededX917RNG是一个类模板。
这里写图片描述

源代码如下:

#include<cryptlib.h>
#include<osrng.h>//包含AutoSeededX917RNG< BLOCK_CIPHER >算法的头文件
#include<rijndael.h>//AES算法
#include<des.h>//DES算法
#include<iostream>
#include<fstream>
#include<stdlib.h>
using namespace std;
using namespace CryptoPP;

#define Array_Size 64

int main()
{
	//定义一个AutoSeededX917RNG< BLOCK_CIPHER >对象
	//AutoSeededX917RNG<AES>  rng;
	AutoSeededX917RNG<DES_EDE3>  rng;
	//定义一个文件对象
	ofstream file("data.dat",ios_base::binary | ios_base::out);

	byte output[Array_Size];

	//产生1Gbits的数据。每调用一次随机数发生器,产生8*64=512bits的数据。
	//1Gbits = 1000*1000*1000。
	//1000*1000*1000/512 = 1953125。

	cout << "开始生成数据..." << endl;
	clock_t start = clock();

	for(int i=0; i < 1953125 ; ++i)
	{
		rng.GenerateBlock(output,Array_Size);
		file.write(reinterpret_cast<const char*>(output),Array_Size);
	}
	clock_t end = clock();
	cout << "数据生成完毕..." << endl;

	double  duration;
	duration = (double)(end - start) / CLOCKS_PER_SEC;
	cout << "生成数据总共耗时:" << duration << endl;

	file.close();

	return 0;
}

执行上述程序,运行结果如下图所示:
这里写图片描述
从运行结果来看,产生同样1G bits数量的随机比特,该随机数发生器所需要的时间明显较长。

更多示例代码详见《深入浅出CryptoPP密码学库》随书电子文档:https://github.com/locomotive-crypto/crypto_book_1st

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值