基于 OpenSSL 生成自签名证书

基于 OpenSSL 生成自签名证书

PKI、CA、SSL、TLS、OpenSSL几个概念

PKI 和 CA

PKI 就是 Public Key Infrastructure 的缩写,翻译过来就是公开密钥基础设施。它是利用公开密钥技术所构建的,解决网络安全问题的,普遍适用的一种基础设施。

PKI 是目前唯一的能够基本全面解决安全问题的可能的方案。 PKI 通过电子证书以及管理这些电子证书的一整套设施,维持网络世界的秩序;通过提供一系列的安全服务,为网络电子商务、电子政务提供有力的安全保障。

通俗点说 PKI 就是一整套安全相关标准,然后基于这套标准体系衍生一系列安全相关的产品,主要目的是保证数据在网络上安全、可靠地传输。

PKI 主要由以下组件组成:

  • 认证中心 CA(证书签发) ;
  • X.500目录服务器(证书保存) ;
  • 具有高强度密码算法(SSL)的安全WWW服务器(即配置了 HTTPS 的 apache) ;
  • Web(安全通信平台): Web 有 Web Client 端和 Web Server 端两部分
  • 自开发安全应用系统 自开发安全应用系统是指各行业自开发的各种具体应用系统,例如银行、证券的应用系统等。

CA 是 PKI 的"核心",即数字证书的申请及签发机关,CA 必须具备权威性的特征,它负责管理 PKI 结构下的所有用户(包括各种应用程序)的证书,把用户的公钥和用户的其他信息捆绑在一起,在网上验证用户的身份,CA 还要负责用户证书的黑名单登记和黑名单发布 。

CA 实现了 PKI 中一些很重要的功能:

  • 接收验证最终用户数字证书的申请;
  • 确定是否接受最终用户数字证书的申请-证书的审批;
  • 向申请者颁发、拒绝颁发数字证书-证书的发放;
  • 接收、处理最终用户的数字证书更新请求-证书的更新;
  • 接收最终用户数字证书的查询、撤销;
  • 产生和发布证书废止列表(CRL);
  • 数字证书的归档;
  • 密钥归档;
  • 历史数据归档;

在这么多功能中,CA 的核心功能就是"发放"和"管理"数字证书:
在这里插入图片描述

  • 9
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是基于 OpenSSL生成签名证书的 C++ 代码示例: ```c++ #include <iostream> #include <openssl/rsa.h> #include <openssl/pem.h> #include <openssl/x509.h> #include <openssl/x509v3.h> int main() { // 初始化 OpenSSLOpenSSL_add_all_algorithms(); ERR_load_BIO_strings(); ERR_load_crypto_strings(); // 创建 RSA 密钥对 RSA *rsa = RSA_generate_key(2048, RSA_F4, NULL, NULL); EVP_PKEY *pkey = EVP_PKEY_new(); EVP_PKEY_assign_RSA(pkey, rsa); // 创建证书请求 X509_REQ *req = X509_REQ_new(); X509_REQ_set_version(req, 0L); X509_REQ_set_pubkey(req, pkey); // 设置证书请求的主题信息 X509_NAME *name = X509_NAME_new(); X509_NAME_add_entry_by_txt(name, "CN", MBSTRING_ASC, (unsigned char*)"example.com", -1, -1, 0); X509_REQ_set_subject_name(req, name); // 签名证书请求,生成证书 X509 *cert = X509_new(); X509_set_version(cert, 2L); ASN1_INTEGER_set(X509_get_serialNumber(cert), 1); X509_gmtime_adj(X509_get_notBefore(cert), 0); X509_gmtime_adj(X509_get_notAfter(cert), 31536000L); X509_set_subject_name(cert, X509_REQ_get_subject_name(req)); X509_set_pubkey(cert, X509_REQ_get_pubkey(req)); X509_set_issuer_name(cert, X509_get_subject_name(cert)); X509_sign(cert, pkey, EVP_sha256()); // 将证书写入文件 BIO *bio_cert = BIO_new_file("example.crt", "w"); PEM_write_bio_X509(bio_cert, cert); // 将私钥写入文件 BIO *bio_key = BIO_new_file("example.key", "w"); PEM_write_bio_PrivateKey(bio_key, pkey, NULL, NULL, 0, NULL, NULL); // 释放资源 X509_REQ_free(req); X509_free(cert); EVP_PKEY_free(pkey); X509_NAME_free(name); BIO_free_all(bio_cert); BIO_free_all(bio_key); return 0; } ``` 这段代码将生成一个自签名证书,并将其保存到 example.crt 文件中,同时将私钥保存到 example.key 文件中。你可以按照自己的需求修改代码中的证书主题、有效期等信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值