【常见开源库的二次开发】基于openssl的加密与解密——openssl认识与配置(一)

目录:

目录:

一、什么是openssl?

二、所需要具备的开发工具

三、Windows上编译OpenSSL3.0

四、Linux编译openssl3.0


一、什么是openssl?

OpenSSL 是一个开源的软件库**,它提供了一系列加密工具和协议,主要用于实现安全通信** ,如在网络上的数据传输。它支持多种加密算法,包括对称加密、非对称加密、散列函数、伪随机数生成器、数字签名、密钥交换以及证书管理等。

在 2020 年 5 月 15 日,OpenSSL 发布了 3.0 版本的 Alpha2 测试版,这个版本的一个显著特点是增加了对中国国家密码管理局推荐的密码算法(国密)的支持,包括 SM2(非对称加密算法)、SM3(散列算法)和 SM4(对称加密算法)。

OpenSSL 不仅是一个独立的工具包,它还被广泛集成到其他软件中,以提供加密和安全通信功能。例如

  • **MySQL:**一个流行的开源关系数据库管理系统,可以使用 OpenSSL 来加密客户端和服务器之间的通信。
  • Python: 一种广泛使用的编程语言,其标准库中包含了使用 OpenSSL 的模块,如 ssl 模块,用于实现 SSL/TLS 加密。
  • **libevent:**一个事件通知库,它可以在网络编程中使用 OpenSSL 来提供加密的网络通信。

二、所需要具备的开发工具

安装好Vs2019社区版本

下载:openssl.vip

安装好ubuntu18.04系统

图2-1 vs2019社区版下载

图2-2 openssl-3.0.0源码下载

图2-3 openssl-3.0.0源码中获取到的文件

三、Windows上编译OpenSSL3.0

openssl.vip安装过程和工具下载

安装vs2019 perl

配置nasm

将这里的nasm压缩包解压

得到这些文件:

配置环境变量:

打开x86编译工具:

生成项目文件perl Configure VC-WIN32

perl Configure VC-WIN64A --prefix=%cd%\out

运行控制台x86 Native Tools Command Prompt for VS2019

nmake

重新生成makefile

cpp 复制代码
perl Configure VC-WIN632

出现没有找到dmake的错误

修改makefile文件

黄色标记处将:/O2 修改为 /Od,并注意去除 /debug项,否则生成的Release版本哦!

再次nmake && nmake install进行编译

生成以下目录:

四、Linux编译openssl3.0

Linux中的相关配置安装:

cpp 复制代码
root@100ask:~# apt-get install g++
cpp 复制代码
root@100ask:~# apt-get install make 
cpp 复制代码
root@100ask:~# apt-get install gdb
cpp 复制代码
root@100ask:~# apt-get install git
cpp 复制代码
root@100ask:~# apt-get install wget

下载openssl源码:

cpp 复制代码
root@100ask:~# wget https://www.openssl.org/source/openssl-3.0.0-alpha2.tar.gz

进行解压源代码:

cpp 复制代码
root@100ask:~# tar -xvf openssl-3.0.0-alpha2.tar.gz

进入子路径:

cpp 复制代码
root@100ask:~# cd openssl-3.0.0-alpha2

生成makefile

cpp 复制代码
root@100ask:~/openssl-3.0.0-alpha2# ./config

#三十二线程编译

cpp 复制代码
root@100ask:~/openssl-3.0.0-alpha2# make -j32

#安装so库,头文件和说明文档

cpp 复制代码
root@100ask:~/openssl-3.0.0-alpha2# make install

openssl命令行usr/local

cpp 复制代码
root@100ask:~# cd /usr/local

配置安装在usr/local/ssl

头文件/usr/local/include/openssl

so库文件usr/local/Iib

将此项目示例放入到Linux中:

**test_openssl.cpp :**生成随机数字

cpp 复制代码
#include  <iostream>
#include  <openssl/rand.h>
#include  <openssl/des.h>
#include  <openssl/bio.h>
#include  <time.h>
#include  <thread>

//  在Windows平台下,为了解决链接问题,需要包含applink.c
#ifdef  _WIN32
#include  <openssl/applink.c>
#endif

using  namespace  std;

int  main(int  argc,  char  *argv[])
{
      cout  <<  "测试  OpenSSL"  <<  endl;
      //  使用时间戳作为随机数的种子
      time_t  t  =  time(0);
      RAND_seed(&t,  sizeof(t));
      auto  mem_bio  =  BIO_new(BIO_s_mem());

      //  生成随机数
      unsigned  char  buf[16]  =  {0};
      int  len  =  sizeof(buf);
      int  re  =  RAND_bytes(buf,  len);
      for  (int  i  =  0;  i  <  len;  i++)
      {
          cout  <<  "["  <<  (int)buf[i]  <<  "]";
      }

      //  清理资源
      BIO_free(mem_bio);

      return  0;
}

使用 OpenSSL 库生成随机数的一个简单示例,代码首先打印出 "测试 OpenSSL",然后使用当前时间作为种子来初始化随机数生成器。接下来创建了一个内存 BIO 对象,并使用 RAND_bytes 函数生成了一个 16 字节的随机数。最后,代码遍历并打印出随机数的每个字节。在结束前,代码释放了分配给 BIO 对象的资源。

编写makefile

bash 复制代码
first_openss:test_openssl.cpp
        g++ $^ -o $@ -I/usr/local/include -L/usr/local/lib -lcrypto
相关推荐
van叶~4 分钟前
Linux探秘坊-------4.进度条小程序
linux·运维·小程序
秋风&萧瑟5 分钟前
【数据结构】顺序队列与链式队列
linux·数据结构·windows
我科绝伦(Huanhuan Zhou)12 分钟前
Linux 系统服务开机自启动指导手册
java·linux·服务器
hunter2062062 小时前
ubuntu终端当一段时间内没有程序运行时,自动关闭终端。
linux·chrome·ubuntu
代码讲故事4 小时前
从Windows通过XRDP远程访问和控制银河麒麟ukey v10服务器,以及多次连接后黑屏的问题
linux·运维·服务器·windows·远程连接·远程桌面·xrdp
qq_243050796 小时前
irpas:互联网路由协议攻击套件!全参数详细教程!Kali Linux入门教程!黑客渗透测试!
linux·网络·web安全·网络安全·黑客·渗透测试·系统安全
IT北辰6 小时前
Linux下 date时间应该与系统的 RTC(硬件时钟)同步
linux·运维·实时音视频
Jason Yan6 小时前
【经验分享】ARM Linux-RT内核实时系统性能评估工具
linux·arm开发·经验分享
步、步、为营7 小时前
.net无运行时发布原理
linux·服务器·.net
等一场春雨8 小时前
CentOS 安装Redis
linux·redis·centos