C语言OpenSSL安装和使用

安装

要使用OpenSSL库进行C语言编程,你需要完成以下步骤:

  1. **安装OpenSSL库**:

首先,你需要确保在你的系统上安装了OpenSSL库。如果你使用的是Linux或类Unix系统,你可以使用包管理器安装OpenSSL。例如,在Ubuntu上,你可以运行以下命令:

```bash

sudo apt-get install libssl-dev

```

如果你使用的是Windows,你可以从OpenSSL官方网站(https://www.openssl.org/)下载预编译的Windows版本。

  1. **包含头文件**:

在你的C代码中,你需要包含OpenSSL的头文件。这些头文件包含了OpenSSL库中定义的函数和数据结构。

```c

#include <openssl/rsa.h>

#include <openssl/pem.h>

```

  1. **初始化OpenSSL库**:

在使用OpenSSL之前,需要初始化OpenSSL库。这可以通过调用以下函数来完成:

```c

OpenSSL_add_all_algorithms();

ERR_load_crypto_strings();

```

这些函数将加载OpenSSL支持的所有密码学算法以及错误处理信息。

  1. **使用OpenSSL功能**:

现在,你可以使用OpenSSL库中提供的函数来执行各种密码学操作,例如生成密钥对、加密、解密、签名和验证等。

  1. **清理资源**:

在程序结束时,确保释放分配的资源。例如,释放RSA密钥对可以使用以下函数:

```c

RSA_free(keypair);

```

释放BIO(OpenSSL的I/O抽象)可以使用以下函数:

```c

BIO_free_all(bp_public);

BIO_free_all(bp_private);

```

这是一个基本的OpenSSL使用示例。请注意,OpenSSL库具有广泛的功能和配置选项,具体取决于你要执行的任务。在实际项目中,你可能需要查阅OpenSSL的文档以获取更详细的信息和示例代码。要构建包含OpenSSL库的C程序,你需要使用适当的编译器选项,以确保正确链接OpenSSL库。

使用

这个错误消息表明编译器找不到链接到OpenSSL库的符号。你需要确保在编译时正确链接OpenSSL库。在使用gcc编译器时,需要添加 `-lssl -lcrypto` 选项来链接OpenSSL库。

尝试以下步骤:

  1. 编译你的程序时,请确保添加 `-lssl -lcrypto` 选项来链接OpenSSL库。例如:

```bash

gcc -o myprogram myprogram.c -lssl -lcrypto

```

这将告诉编译器去链接OpenSSL库中的符号。

  1. 确保OpenSSL库在你的系统中正确安装。你可以使用以下命令来查找OpenSSL的安装路径:

```bash

pkg-config --cflags --libs openssl

```

这将输出OpenSSL的编译和链接选项。

  1. 如果你使用了自定义的安装路径,请确保将这些路径包含在编译命令中,例如:

```bash

gcc -o myprogram myprogram.c -I/path/to/openssl/include -L/path/to/openssl/lib -lssl -lcrypto

```

其中 `/path/to/openssl/include` 是 OpenSSL 头文件的路径,`/path/to/openssl/lib` 是 OpenSSL 库文件的路径。

通过这些步骤,你应该能够解决链接错误并成功编译你的程序。确保你的编译器可以找到OpenSSL库,以便能够使用OpenSSL函数。

例程

cpp 复制代码
#include <openssl/rsa.h>
#include <openssl/pem.h>
#include <openssl/err.h> // 引入错误处理头文件

int main() {
    RSA *keypair;
    BIGNUM *bne;
    BIO *bp_public = NULL, *bp_private = NULL;
    int bits = 2048; // 密钥位数

    // 初始化OpenSSL
    OpenSSL_add_all_algorithms();
    
    // 根据OpenSSL版本使用正确的函数
    #if OPENSSL_VERSION_NUMBER >= 0x30000000L
    OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL);
    #else
    ERR_load_crypto_strings();
    #endif

    // 创建RSA密钥对生成器
    bne = BN_new();
    if (BN_set_word(bne, RSA_F4) != 1) {
        fprintf(stderr, "BN_set_word failed\n");
        return 1;
    }

    // 生成RSA密钥对
    keypair = RSA_new();
    if (RSA_generate_key_ex(keypair, bits, bne, NULL) != 1) {
        fprintf(stderr, "RSA_generate_key_ex failed\n");
        return 1;
    }

    // 保存公钥和私钥到文件
    bp_public = BIO_new_file("public.pem", "w");
    bp_private = BIO_new_file("private.pem", "w");
    if (PEM_write_bio_RSAPublicKey(bp_public, keypair) != 1) {
        fprintf(stderr, "PEM_write_bio_RSAPublicKey failed\n");
        return 1;
    }
    if (PEM_write_bio_RSAPrivateKey(bp_private, keypair, NULL, NULL, 0, NULL, NULL) != 1) {
        fprintf(stderr, "PEM_write_bio_RSAPrivateKey failed\n");
        return 1;
    }

    // 释放资源
    RSA_free(keypair);
    BIO_free_all(bp_public);
    BIO_free_all(bp_private);
    BN_free(bne);

    return 0;
}
相关推荐
lb36363636362 小时前
分享一下arr的意义(c基础)(必看)(牢记)
c语言·知识点
Swift社区3 小时前
在 Swift 中实现字符串分割问题:以字典中的单词构造句子
开发语言·ios·swift
没头脑的ht3 小时前
Swift内存访问冲突
开发语言·ios·swift
没头脑的ht3 小时前
Swift闭包的本质
开发语言·ios·swift
wjs20243 小时前
Swift 数组
开发语言
南东山人4 小时前
一文说清:C和C++混合编程
c语言·c++
stm 学习ing4 小时前
FPGA 第十讲 避免latch的产生
c语言·开发语言·单片机·嵌入式硬件·fpga开发·fpga
湫ccc5 小时前
《Python基础》之字符串格式化输出
开发语言·python
mqiqe6 小时前
Python MySQL通过Binlog 获取变更记录 恢复数据
开发语言·python·mysql