Openssl数据安全传输平台004:Socket C-API封装为C++类 / 服务端及客户端代码框架和实现

0. 代码仓库

https://github.com/Chufeng-Jiang/OpenSSL_Secure_Data_Transmission_Platform

1. 客户端C API

// 客户端
// C API
int sckClient_init();
/* 客户端 连接服务器 */
int sckClient_connect(char *ip, int port, int connecttime, int *connfd);
/* 客户端 关闭和服务端的连接 */
int sckClient_closeconn(int connfd);
/* 客户端 发送报文 */
int sckClient_send(int connfd, int sendtime, unsigned char *data, int datalen);
/* 客户端 接受报文 */
int sckClient_rev(int connfd, int revtime, unsigned char **out, int *outlen); //1
/* 释放内存 */
int sck_FreeMem(void **buf);
/* 客户端 释放 */
int sckClient_destroy();

2. 客户端C API的封装分析

2.1 sckClient_init()和sckClient_destroy()

int sckClient_init(); 可以使用构造函数代替

TcpSocket();
TcpSocket(int fd);
~TcpSocket();

2.2 sckClient_connect

  1. 由于几乎所有的API都有参数int *connfd,所以直接将其设置一个私有的成员变量,并且从所有的API参数列表中移除。
  2. C++使用string来拷贝字符串比char方便

/* 客户端 连接服务器 */
int sckClient_connect (char *ip, int port, int connecttime, int *connfd );

int conectToHost(string ip, unsigned short port, int connecttime)

int m_connfd;

2.3 sckClient_closeconn()

/* 客户端 关闭和服务端的连接 */
int sckClient_closeconn(int connfd );

int disConnect();

2.4 sckClient_send()

unsigned char *data, int datalen 是要发送的数据,直接修改为string sendMsg

/* 客户端 发送报文 */
int sckClient_send(int connfd, int sendtime, unsigned char *data, int datalen);

int sendMsg(string sendMsg, int sendtime = 10000)

2.5 sckClient_rev()

/* 客户端 接受报文 */
int sckClient_rev(int connfd, int revtime, unsigned char **out, int *outlen);

string recvMsg(int timeout)

2.6 sck_FreeMem

/* 释放内存 */
int sck_FreeMem(void **buf);

3. 客户端C++ API

// 创建TcpSocket对象 == 一个连接, 这个对象就可以和服务器通信了, 多个连接需要创建多个这样的对象

class TcpSocket
{
public:
   TcpSocket();
   TcpSocket(int fd);
   ~TcpSocket();
   
   /* 客户端 连接服务器 */
   int conectToHost(string ip, unsigned short port, int connecttime);
   /* 客户端 关闭和服务端的连接 */
   int disConnect();
   /* 客户端 发送报文 */
   int sendMsg(string sendMsg, int sendtime = 10000);
   /* 客户端 接受报文 */
   string recvMsg(int timeout);

private:
   int m_connfd;
}

4. 服务端C API

// 服务器端
/* 服务器端初始化 */
int sckServer_init(int port, int *listenfd);
int sckServer_accept(int listenfd, int timeout, int *connfd);
/* 服务器端发送报文 */
int sckServer_send(int connfd, int timeout, unsigned char *data, int datalen);
/* 服务器端端接受报文 */
int sckServer_rev(int  connfd, int timeout, unsigned char **out, int *outlen); //1
int sckServer_close(int connfd);
/* 服务器端环境释放 */
int sckServer_destroy();

5. 服务端C++

// 这个类不能用, 因为只能和一个客户端建立连接
class TcpServer
{
public:
    // 初始化监听的套接字: 创建, 绑定, 监听
    TcpServer();
    ~TcpServer();    // 在这里边关闭监听的fd

    int acceptConn(int timeout);
    /* 服务器 发送报文 */
    int sendMsg(string sendMsg, int sendtime = 10000);
    /* 服务器 接受报文 */
    string recvMsg(int timeout); 
    int disConnect();    // 和客户端断开连接
private:
    int m_lfd;        // 监听的文件描述符
    int m_connfd;    // 通信的文件描述符
}

6. 客户端和服务端代码框架

在这里插入图片描述

7.代码实现

7.1 服务端代码实现

在这里插入图片描述

7.2 客户端代码实现

在这里插入图片描述

更多关于C API封装为C++类,参考

  • 可以直接进行阅读,没有线程池以外的新知识

Openssl数据安全传输平台013:手写C/C++线程池 --C API封装为C++类

面向工程应用:市面上的一些密码学课程和密码学的书籍,很多都是从考证出发,讲解算法原理并不面向工程应用,而我们现在缺少的是工程应用相关的知识,本课程从工程应用出发,每种技术都主要讲解其在工程中的使用,并演示工程应用的代码。 从零实现部分算法: 课程中实现了base16编解码 ,XOR对称加解密算法,PKCS7 pading数据填充算法,通过对一些简单算法的实现,从而加深对密码学的理解。理论与实践结合: 课程如果只是讲代码,同学并不能理解接口背后的原理,在项目设计中就会留下隐患,出现错误也不容易排查出问题。如果只讲理论,比如对密码学的一些研究,对于大部分从事工程应用的同学并没有必要,而是理论与实践结合,一切为了工程实践。代码现场打出: 代码不放在ppt而是现场打出,更好的让学员理解代码编写的逻辑,老师现场敲出代码正是展示出了工程项目的思考,每个步骤为什么要这么做,考虑了哪些异常,易学不枯燥: 课程为了确保大部分人开发者都学得会,理解算法原理(才能真正理解算法特性),学会工程应用(接口调用,但不局限接口调用,理解接口背后的机制,并能解决工程中会出现的问题),阅读算法源码但不实现密码算法,,并能将密码学投入到实际工程中,如果是想学习具体的加密算法实现,请关注我后面的课程。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大大枫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值