3

我正在尝试使用此处第 7.7 节中的示例使 CyaSSL 的 Keygen 功能工作:http ://www.yassl.com/yaSSL/Docs-cyassl-manual-7-keys-and-certificates.html

我正在使用带有 --enable-keygen 选项的 CyaSSL 3.2.0,但也无法使其与 3.1.0 一起使用。

这是代码:

#include <stdio.h>
#include <cyassl/ctaocrypt/asn.h>
#include <cyassl/ctaocrypt/rsa.h>

int main() {
        RsaKey genKey;
        RNG rng;
        int ret;

        printf("%d\n",InitRng(&rng));
        printf("%d\n",InitRsaKey(&genKey, 0));
        ret = MakeRsaKey(&genKey, 1024, 65537, &rng);

        printf("ret: %d\n",ret);

        return 0;
}

我在 InitRsaKey 行中遇到分段错误,大概是由于无效写入或其他原因。

有人知道我的问题可能出在哪里吗?任何帮助表示赞赏

4

1 回答 1

2

早上好,请不要忘记包含 options.h 标头。这将确保您在项目中获得正确的配置设置,例如,如果您使用 --enable-keygen 配置 CyaSSL 然后查看 cyassl/options.h,您将看到#undef CYASSL_KEY_GEN后面跟着的行#define CYASSL_KEY_GEN。同样在你的 makefile 中不要忘记包含 cyassl 库。这可以-lcyassl在您的构建线中使用。请参阅下面的代码以供参考:

#include <stdio.h>
#include <cyassl/options.h> //pull in the define for CYASSL_KEY_GEN
#include <cyassl/ctaocrypt/asn.h>
#include <cyassl/ctaocrypt/rsa.h>

int main() {
        RsaKey genKey;
        RNG rng;
        int ret;

        printf("%d\n",InitRng(&rng));
        printf("%d\n",InitRsaKey(&genKey, 0));
        ret = MakeRsaKey(&genKey, 1024, 65537, &rng);

        printf("ret: %d\n",ret);

        return 0;
}

生成文件:

 CC=gcc       #you can use clang or other instead of gcc                                                                   
 CFLAGS=-Wall                                                                    
 LIBS=-lpthread -lcyassl #must have -lcyassl in makefile                                                         

 all: run                                                                        

 #NOTE: arrows denote a hard tab, replace them with hard tab in makefile                                                                             
 run: test.o                                                                     
 →→→→$(CC) -o $@ $(LIBS) $^ $(CFLAGS) #put $(LIBS) into build command                                            

 .PHONY: clean all                                                               

 clean:                                                                          
 →→→→rm -f *.o test.o run 
于 2015-03-30T15:58:22.160 回答