QT 开发openSSL CSR证书请求工具

1、环境

QT 5.15.2 MinGW8.1.0 64Bit

OpenSSL 1.1.1f  31 Mar 2020
built on: Wed Nov 24 13:20:48 2021 UTC
platform: debian-amd64
options:  bn(64,64) rc4(16x,int) des(int) blowfish(ptr)

本机的OpenSSL是随QT安装的。


2、QT使用openSSL

2.1 项目文件添加以下依赖

LIBS += $$quote(D:\SoftWareTools\Qt5.15.2_64\Tools\OpenSSL\Win_x64\lib\libcrypto.lib)
LIBS += $$quote(D:\SoftWareTools\Qt5.15.2_64\Tools\OpenSSL\Win_x64\lib\libssl.lib) 
INCLUDEPATH += $$quote(D:\SoftWareTools\Qt5.15.2_64\Tools\OpenSSL\Win_x64\include)

2.2 项目工程中需要添加applink.c,文件位于openssl的include下:

 2.3 生成的exe文件夹下添加dll,在openssl的bin目录:

 3、实现

添加相关头文件:

UI设计:

 关键代码:

void MainWindow::on_pushButton_create_clicked()
{/*! check valid */if (ui->lineEdit_country->text().isEmpty()) {QMessageBox::about(NULL, "notice", "country is empty, error!");return;}if (ui->lineEdit_city->text().isEmpty()) {QMessageBox::about(NULL, "notice", "city is empty, error!");return;}if (ui->lineEdit_province->text().isEmpty()) {QMessageBox::about(NULL, "notice", "province is empty, error!");return;}if (ui->lineEdit_organization->text().isEmpty()) {QMessageBox::about(NULL, "notice", "organization is empty, error!");return;}if (ui->lineEdit_unit->text().isEmpty()) {QMessageBox::about(NULL, "notice", "unit is empty, error!");return;}if (ui->lineEdit_name->text().isEmpty()) {QMessageBox::about(NULL, "notice", "name is empty, error!");return;}/*! create pri and pub key */FILE* private_key_file;FILE* public_key_file;private_key_file = fopen("./prikey.pem", "w+");public_key_file  = fopen("./pubkey.pem", "w+");int bits              = 1024;unsigned long e_value = RSA_3;BIGNUM* bne = BN_new();if (1 != BN_set_word(bne, e_value)) {QMessageBox::about(NULL, "notice", "openssl set bne word error!");BN_free(bne);return;}RSA* rsa = RSA_new();if (1 != RSA_generate_key_ex(rsa, bits, bne, NULL)) {QMessageBox::about(NULL, "notice", "openssl rsa gen error!");RSA_free(rsa);rsa = NULL;return;}PEM_write_RSAPrivateKey(private_key_file, rsa, NULL, NULL, 0, NULL, NULL);PEM_write_RSA_PUBKEY(public_key_file, rsa);RSA_free(rsa);rsa = NULL;BN_free(bne);bne = NULL;fclose(private_key_file);fclose(public_key_file);/*! create csr */// 1. set version of x509 reqX509_REQ* x509_req = X509_REQ_new();int nVersion       = 1;if (1 != X509_REQ_set_version(x509_req, nVersion)) {QMessageBox::about(NULL, "notice", "X509 req set version error!");X509_REQ_free(x509_req);return;}// 2. set subject of x509 reqX509_NAME* x509_name = X509_REQ_get_subject_name(x509_req);const char* pbCN     = NULL; const char* pbOU     = NULL; const char* pbO      = NULL; const char* pbL      = NULL; const char* pbST     = NULL;const char* pbC      = NULL; QByteArray ba;ba.clear();ba.append(ui->lineEdit_name->text().toUtf8());pbCN = ba.data();ba.clear();ba.append(ui->lineEdit_unit->text().toUtf8());pbOU = ba.data();ba.clear();ba.append(ui->lineEdit_organization->text().toUtf8());pbO = ba.data();ba.clear();ba.append(ui->lineEdit_city->text().toUtf8());pbL = ba.data();ba.clear();ba.append(ui->lineEdit_province->text().toUtf8());pbST = ba.data();ba.clear();ba.append(ui->lineEdit_country->text().toUtf8());pbC = ba.data();X509_NAME_add_entry_by_txt(x509_name, "CN", V_ASN1_UTF8STRING, (const unsigned char*)pbCN, -1, -1, 0);X509_NAME_add_entry_by_txt(x509_name, "OU", V_ASN1_UTF8STRING, (const unsigned char*)pbOU, -1, -1, 0);X509_NAME_add_entry_by_txt(x509_name, "O", V_ASN1_UTF8STRING, (const unsigned char*)pbO, -1, -1, 0);X509_NAME_add_entry_by_txt(x509_name, "L", V_ASN1_UTF8STRING, (const unsigned char*)pbL, -1, -1, 0);X509_NAME_add_entry_by_txt(x509_name, "ST", V_ASN1_UTF8STRING, (const unsigned char*)pbST, -1, -1, 0);X509_NAME_add_entry_by_txt(x509_name, "C", V_ASN1_UTF8STRING, (const unsigned char*)pbC, -1, -1, 0);// 3. set public key of x509 reqconst char* key_file_path = "./prikey.pem";BIO* key_file_BIO         = BIO_new_file(key_file_path, "r");if (key_file_BIO == NULL) {QMessageBox::about(NULL, "notice", "BIO new file error!");BIO_free_all(key_file_BIO);X509_REQ_free(x509_req);return;}rsa = PEM_read_bio_RSAPrivateKey(key_file_BIO, NULL, NULL, NULL);if (rsa == NULL) {QMessageBox::about(NULL, "notice", "PEM read bio RSAPrivateKey error!");BIO_free_all(key_file_BIO);X509_REQ_free(x509_req);RSA_free(rsa);return;}EVP_PKEY* pKey = EVP_PKEY_new();EVP_PKEY_assign_RSA(pKey, rsa);rsa = NULL; // will be free rsa when EVP_PKEY_free(pKey)if (1 != X509_REQ_set_pubkey(x509_req, pKey)) {QMessageBox::about(NULL, "notice", "X509 REQ set pubkey error!");BIO_free_all(key_file_BIO);X509_REQ_free(x509_req);EVP_PKEY_free(pKey);RSA_free(rsa);return;}// 4. set sign key of x509 reqint ret = X509_REQ_sign(x509_req, pKey, EVP_sha1()); // return x509_req->signature->lengthif (ret <= 0) {QMessageBox::about(NULL, "notice", "X509 REQ sign error!");BIO_free_all(key_file_BIO);X509_REQ_free(x509_req);EVP_PKEY_free(pKey);RSA_free(rsa);return;}m_file_name = ui->lineEdit_name->text();ba.clear();QString csr_file = m_file_name + ".csr";ba.append(csr_file.toLatin1());BIO* out = BIO_new_file(ba.data(), "w");if (1 == PEM_write_bio_X509_REQ(out, x509_req)) {QMessageBox::about(NULL, "notice", QString("create %1 success!").arg(ui->lineEdit_name->text() + ".csr"));ui->textEdit_csr_msg->append(ui->lineEdit_name->text() + ".csr create success");} else {QMessageBox::about(NULL, "notice", "creat csr error!");}BIO_free_all(key_file_BIO);X509_REQ_free(x509_req);EVP_PKEY_free(pKey);BIO_free_all(out);RSA_free(rsa);
}

 最终实现效果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/404566.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2012网页设计趋势(下)

CSS3 技术 不确定你可以利用CSS3吗&#xff1f;再想想。网络先锋如Andy Clarke 和 Jeremy Keith一直提倡网页设计要“逐步加强”。逐步增强是指在网站设计师时要兼顾到旧版浏览器的可用性&#xff0c;而“增强”则是针对喜欢最新技术的用户。在这样的设计阵营&#xff0c;你利用…

树莓派CM4 装系统和换源

一、系统下载 官网&#xff1a;Operating system images – Raspberry Pi 最新的版本删除了默认账号pi。考虑以前的使用习惯&#xff0c;此处下载以前的buster debian版本。CM4是arm64架构&#xff0c;根据板子的配置容量不同可选相应的版本&#xff0c;我这里选择lite版本。…

C++沉思录

C沉思录 第五章 代理类 : 为了实现容器或数组的多态性。 1 #include <iostream> 2 3 using namespace std; 4 5 class Vehicle 6 { 7 public: 8 virtual void start() const 0 ; 9 virtual Vehicle* copy() const 0 ;10 virtual ~Vehicle() {};11 };12 1…

VC内存泄露检查工具:VisualLeakDetector

From: http://www.xdowns.com/article/170/Article_3060.html 初识Visual Leak Detector 灵活自由是C/C语言的一大特色&#xff0c;而这也为C/C程序员出了一个难题。当程序越来越复杂时&#xff0c;内存的管理也会变得越加复杂&#xff0c;稍有不慎就会出现内存问题。内…

JQuery Easy Ui 可装载组合框 - ComboBox

JQuery Easy Ui 可装载组合框 - ComboBox 可装载组合框 - ComboBox 继承自$.fn.combo.defaults,通过$.fn.combobox.defaults覆盖默认值 combobox显示的是一个可以编辑的文本框和一个下拉列表.允许用户从里面选择一个或者是多个值,用户可以直接输入值到列表顶部,或者可以从列表选…

用SQL实现统计报表中的“小计”和“合计”

客户提出需求&#xff0c;针对某一列分组加上小计&#xff0c;合计汇总。网上找了一些有关SQL加合计的语句。都不是很理想。决定自己动手写。 思路有三个&#xff1a; 1.很多用GROUPPING和ROLLUP来实现。 优点实现代码简洁&#xff0c;要求对GROUPPING和ROLLUP很深的理解。 …

Linux串口驱动程序-termios结构体中的VTIME和VMIN应用

#Linux串口驱动程序-termios结构体中的VTIME和VMIN应用 参考 https://tldp.org/HOWTO/Serial-Programming-HOWTO/x115.html 最近在看Unix-linux系统编程一书&#xff0c;做到第六章的时候需要做一个标准输入的超时处理。如下图所示 需要改动的&#xff0c;是原书的play_aga…

C# 线程手册 第一章 线程定义 .NET 和 C# 对线程的支持

由于.NET Framework 支持自由线程&#xff0c;所以自由线程在所有.NET 语言中都存在&#xff0c;包括C#和VB.NET. 在下一部分&#xff0c;我们将着重关注如何提供这种支持以及更多关于线程是如何做到的&#xff0c;而不再关注线程是什么。我们将讨论一些能够进一步帮助区分进程…

前端第一天 HTML基础

前端第一天 HTML基础 1.是什么 HTML里值得记住的就几个点&#xff0c;第一&#xff0c;这东西还有自身也有结构 这东西是个超文本&#xff0c;可以挂载文字图片视频或者别的超文本自身可以通过各种各样的tag进行标记&#xff0c;排版给浏览器提供渲染的依据&#xff0c; 2.…

view2.0移植自定义图标,带颜色修改

1.下载你的iconfont项目 1.将图标添加到项目&#xff0c;修改font-family值 2.下载项目打包文件&#xff0c;解压后如图所示 我们只关心里面的iconfont.css和iconfont.json 我们在这个文件夹&#xff0c;新建一个convert.js,内容如下 //convert.js let path1 "./iconf…

H3C——路由策略和策略路由实例配置

配置如下&#xff1a;[IP]int s0/2/0[IP-Serial0/2/0]ip add 202.112.1.10 28[IP-Serial0/2/0]int s0/2/1[IP-Serial0/2/1]ip add 61.67.1.10 28 [IP-Serial0/2/1]int lo0[IP-LoopBack0]ip add 10.10.10.10 32[IP]ip route-static 0.0.0.0 0 202.112.1.9 指条静态缺省路由到R1 …

功能:人脉(People Hub)7-固定到“开始”屏幕

如果是您的亲人和密友&#xff0c;再或者是领导和重要客户。 您需要经常沟通&#xff0c;可以将他的联系人头像固定在开始屏幕上&#xff0c;方便您的沟通。方法&#xff1a;很简单&#xff0c;“长按该联系人”后&#xff0c;有菜单出现&#xff0c;选择弹出菜单中的“固定到‘…

《OEA - 实体扩展属性系统 - 设计方案说明书》

这篇设计文档是 12 月份写来参加公司的研发峰会的&#xff0c;自己倒是信心满满&#xff0c;不过最后还是没有入围。现在想想也没啥大用&#xff0c;所以贴出来&#xff0c;期待与园友交流。 文档有点长&#xff0c;没全部贴在博客中&#xff0c;有兴趣的可以下载附件中的 PDF。…

Amazon S3 设置对象的生命周期Lifecycle

2019独角兽企业重金招聘Python工程师标准>>> 保存在S3上面的文件&#xff0c;有些是长期保存的&#xff0c;而有一些我们却不希望保存太久&#xff0c;过一段时间后就可以删除了。例如备份文件&#xff0c;太旧的就要删除&#xff1b;又或如日志文件&#xff0c;只保…

Direct3D提高篇:HLSL编程实现PhotoShop滤镜效果 - 伪 HDR/Blow

所谓HDR就是高动态范围的意思。在普通的显示器和位图里&#xff0c;每通道都是8-bit&#xff0c;也就是说RGB分量的范围都是0-255&#xff0c;这用来表示现实中的颜色显然是远远不够的。现实中的图像的动态范围远远大的多&#xff0c;那么如何在现有的显示设备里尽可能的保持更…

Oracle Buffer Cache的keep、recycle、default pool概念图解

Oracle Buffer Cache的keep、recycle、default pool概念图解 转载于:https://blog.51cto.com/maclean/1278284

程序中调用命令行命令,不显示那个黑黑的DOS窗口

From: http://hi.baidu.com/yanqiuge/item/5da466c3d3f18453ad00ef1d 在程序中使用命令行时&#xff0c;会有黑黑的DOS窗口&#xff0c;很不爽&#xff0c;在网上查了一下&#xff0c;写一个有点实用价值的小程序&#xff1a; /****************************** 文件名&#…

Oracle Row cache lock图解

Oracle Row cache lock(dictionary cache)图解 转载于:https://blog.51cto.com/maclean/1278273

windows平台编译vlc

From: http://blog.csdn.net/guanshangming/article/details/5581270 转自:http://jeremiah.blog.51cto.com/539865/114190Jeremiah刚刚工作几个月&#xff0c;参与的第一个项目是与视频监控有关&#xff0c;分配给我的任务就是用开源的vlc做一个自己的播放器。对于开源项目来…

Appium--环境搭建

Appium介绍 Appium是一个移动端的自动化框架&#xff0c;可以做H5、Web测试、可以做功能测试&#xff08;Android、IOS&#xff09;、可以做跨进程测试&#xff0c;且是跨平台的。Appium做测试的时候支持的语言有很多种&#xff0c;包括java、Python、ruby、PHP、C#等。由于我熟…