我希望编写一个openssl动态引擎,但是我找不到任何相关的文档。
我想要编写的算法是一个加密算法(例如RSA)和一个哈希算法(例如MD5)。
有没有一些简单的引擎源代码,我可以修改并使用?
我希望编写一个openssl动态引擎,但是我找不到任何相关的文档。
我想要编写的算法是一个加密算法(例如RSA)和一个哈希算法(例如MD5)。
有没有一些简单的引擎源代码,我可以修改并使用?
有没有简单的引擎源代码可以更改并使用?
英特尔的RDRAND
引擎非常容易理解。您可以在以下位置找到其源代码:
openssl-1.0.1f$ grep -R -i ENGINE_rdrand *
crypto/engine/eng_rdrand.c:static ENGINE *ENGINE_rdrand(void)
crypto/engine/eng_rdrand.c: ENGINE *toadd = ENGINE_rdrand();
以下是如何加载并将其设置为默认的随机数生成器引擎(来源于随机数|硬件):
unsigned long err = 0;
int rc = 0;
OPENSSL_cpuid_setup();
ENGINE_load_rdrand();
ENGINE* eng = ENGINE_by_id("rdrand");
err = ERR_get_error();
if(NULL == eng) {
fprintf(stderr, "ENGINE_load_rdrand failed, err = 0x%lx\n", err);
abort(); /* failed */
}
rc = ENGINE_init(eng);
err = ERR_get_error();
if(0 == rc) {
fprintf(stderr, "ENGINE_init failed, err = 0x%lx\n", err);
abort(); /* failed */
}
rc = ENGINE_set_default(eng, ENGINE_METHOD_RAND);
err = ERR_get_error();
if(0 == rc) {
fprintf(stderr, "ENGINE_set_default failed, err = 0x%lx\n", err);
abort(); /* failed */
}
/* OK to proceed */
...
ENGINE_finish(eng);
ENGINE_free(eng);
我建议你这样做
apt-get source openssl
这将给您提供openssl源代码。在树中,您可以找到例如crypto/rsa和crypto/md5目录,这可能是您项目的良好起点。此外,它还附带了一些README等形式的文档。
祝玩得愉快。