Crypto++“Tee”式过滤器

2024-03-28

我正在研究根据某些条件处理数据流。

数据从输入管道读取、处理并推送到 Crypto++CBC_Mode<AES>以 a 结尾的过滤器FileSink.

现在,我想“窥探”加密和文件存储之间流动的数据,计算校验和。出于性能原因,我想在流式传输时执行此操作,重新打开输出文件并计算哈希和,这对于我的需求来说是不合理的。

据我所知,要实现此功能,缺少的是某种形式的“tee”过滤器。将数据链分成两条新链,一条用于存储到文件,一条用于哈希计算。

Crypto++中有这样的功能吗?我可以自己实现这样的过滤器吗?如果可以,是否有一些关于自定义 Crypto++ 过滤器所需的指南或示例?还有其他方法可以即时计算校验和吗?


据我所知,要实现此功能,缺少的是某种形式的“tee”过滤器。 ... Crypto++中有这样的功能吗?

是的,它被称为ChannelSwitch。以下内容来自于ChannelSwitch 上的 Crypto++ wiki 页面 http://www.cryptopp.com/wiki/ChannelSwitch,它遵循 Wei Dai 在他的测试文件中对该类的使用。

MD5 hashMD5;
HashFilter filterMD5(hashMD5);

SHA1 hashSHA1;
HashFilter filterSHA1(hashSHA1);

std::auto_ptr<ChannelSwitch> channel( new ChannelSwitch );

channel->AddDefaultRoute(filterMD5);
channel->AddDefaultRoute(filterSHA1);

StringSource ss( "abcdefghijklmnopqrstuvwxyz", true, channel.release());

string digest;
HexEncoder encoder( new StringSink( digest ), true /* uppercase */ ); 

filterMD5.TransferTo( encoder );
cout << filterMD5.AlgorithmName() << ": " << digest << endl;
digest.erase();

filterSHA1.TransferTo( encoder );
cout << filterSHA1.AlgorithmName() << ": " << digest << endl;
digest.erase();

这是上面示例的输出:

$ ./cryptopp-test.exe
MD5: C3FCD3D76192E4007DFB496CCA67E13B
SHA-1: 32D10C7B8CF96570CA04CE37F2A19D84240D3A89

这是另一个使用不同接收器的示例,可能更容易理解:

byte data[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
string e1, e2, e3;

HexEncoder r1(new StringSink(e1));
Base32Encoder r2(new StringSink(e2));
Base64Encoder r3(new StringSink(e3));

ChannelSwitch chsw;
chsw.AddDefaultRoute(r1);
chsw.AddDefaultRoute(r2);
chsw.AddDefaultRoute(r3);

chsw.Put(data, sizeof(data));
chsw.MessageEnd();

cout << e1 << endl;
cout << e2 << endl;
cout << e3 << endl;

这是示例的输出:

$ ./cryptopp-test.exe
0102030405060708090A
AEBAGBAFA2DSSCIK
AQIDBAUGBwgJCg==
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Crypto++“Tee”式过滤器 的相关文章

随机推荐