c - 如何通过 C 中的套接字使用 OpenSSL 公钥发送然后加密消息?

标签 c sockets encryption openssl

我正在使用 C 和本地套接字编写一个简单的服务器和客户端程序。我已经使用以下代码使用 openSSL 成功生成了公钥和私钥:

int generateKeys(char* publicDest, char* privateDest) {

    RSA *keypair = RSA_generate_key(2048, 3, NULL, NULL);

    BIO *pri = BIO_new(BIO_s_mem());
    BIO *pub = BIO_new(BIO_s_mem());

    PEM_write_bio_RSAPrivateKey(pri, keypair, NULL, NULL, 0, NULL, NULL);
    PEM_write_bio_RSAPublicKey(pub, keypair);

    size_t pri_len = BIO_pending(pri);
    size_t pub_len = BIO_pending(pub);

    char *pri_key = malloc(pri_len + 1);
    char *pub_key = malloc(pub_len + 1);

    BIO_read(pri, pri_key, pri_len);
    BIO_read(pub, pub_key, pub_len);

    pri_key[pri_len] = '\0';
    pub_key[pub_len] = '\0';

    strcpy(publicDest, pub_key);
    strcpy(privateDest, pri_key);

}

我现在需要将公钥发送给客户端,以便他们能够为服务器加密他们的消息。我这样做如下:

    char publicKey[2048];
    char privateKey[2048];
    generateKeys(publicKey, privateKey);
    write(clientSocket, publicKey, 2048);

首先,这是向客户端发送公钥的正确方法吗?

这就是我现在遇到的问题,我如何仅使用公钥在客户端加密消息?可能吗?

编辑 - 这是我在客户端尝试加密消息的代码:

    char dest[2048];
    BIO *pubBio = BIO_new_mem_buf(publicKey, -1);

    RSA *pubRSA = PEM_read_bio_RSA_PUBKEY(pubBio, NULL, NULL, NULL);
    if(!pubRSA) {
            printf("Issue loading public key...");
    }
    RSA_public_encrypt(sizeof(sigMessage), sigMessage, dest, pubRSA, RSA_PKCS1_PADDING);

我的问题是我无法以这种方式加载公钥。

最佳答案

First off, is this the correct way to send a public key to the client?

没有。它甚至不是保存 key 的有效方法。对二进制数据使用 strcpy() 是无效的。您应该使用 memcpy()。

how do I encrypt the message on the client-side only using the public key?

您需要显示一些代码以供评论。

Is it possible?

当然可以,但是为什么呢?为什么不使用 SSL/TLS?

关于c - 如何通过 C 中的套接字使用 OpenSSL 公钥发送然后加密消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35188150/

相关文章:

c - 边界填充算法中途停止填充

c - 从主字符串中查找子字符串

c - 哈希表打印 "Stops Working"

c# - 将 byte[] 从 Android 应用程序传递到 C# 控制台应用程序?

javascript - Vorlon.js 正在请求 Socket.io,但它的配置已经设置为包含 socket.io

javascript - 在 POST 中加密数据

C++:反转这个散列?

c - 如何使用多个 pthreads 来评估程序中的表达式

sockets - 如何保持连接以在不请求的情况下将实时数据发送到远程客户端

c++ - 如何使数组成为 C++ 中函数的参数?