OpenHarmony源码分析之分布式软总线:trans_service模块(6)/TCP会话管理

一、概述

trans_service模块基于系统内核提供的socket通信,向authmanager模块提供设备认证通道管理和设备认证数据的传输;向业务模块提供session管理和基于session的数据收发功能,并且通过GCM模块的加密功能提供收发报文的加解密保护。 本文是分布式软总线的会话管理机制的结尾部分,在前文中介绍了新会话中客户端请求数据的处理过程,本文重点介绍普通会话中的新数据处理。衔接OpenHarmony源码分析之分布式软总线:trans_service模块(5)/TCP会话管理 。

DD一下: 欢迎大家关注公众号<程序猿百晓生>,可以了解到一下知识点。

erlang 复制代码
1.OpenHarmony开发基础
2.OpenHarmony北向开发环境搭建
3.鸿蒙南向开发环境的搭建
4.鸿蒙生态应用开发白皮书V2.0 & V3.0
5.鸿蒙开发面试真题(含参考答案) 
6.TypeScript入门学习手册
7.OpenHarmony 经典面试题(含参考答案)
8.OpenHarmony设备开发入门【最新版】
9.沉浸式剖析OpenHarmony源代码
10.系统定制指南
11.【OpenHarmony】Uboot 驱动加载流程
12.OpenHarmony构建系统--GN与子系统、部件、模块详解
13.ohos开机init启动流程
14.鸿蒙版性能优化指南
.......

二、源码分析

  1. 在函数OnProcessDataAvailable()中,先根据会话名称进行判断,该设备是否属于未知设备,如果不是,将进行常规处理。首先根据会话名字在会话管理器的会话监听器表中查找相应会话监听器,若会话监听器已存在,则表明该会话已创建,然后在TcpSessionRecv()中接收会话新数据并进行解密,返回明文数据。TcpSessionRecv()函数的具体分析如下:
ini 复制代码
/*
函数功能:接收TCP会话新数据,并进行解密
函数参数:
    session:tcp通信会话
    buf:用于存储接收到并解密成功的明文数据
    size:除去OVERHEAD_LEN部分的数据长度
    timeout:超时时间
函数返回值:
    成功:返回实际接收到的明文数据长度
    失败:返回TRANS_FAILED(-1)
详细:
*/
static int32_t TcpSessionRecv(TcpSession *session, const char* buf, uint32_t size, int timeout)
{
    if (buf == NULL || session == NULL || session->fd < 0 || size <= 0 || timeout < 0) {
        return TRANS_FAILED;
    }
    char *recvDataBuf = calloc(1, size + OVERHEAD_LEN);
    if (recvDataBuf == NULL) {
        return TRANS_FAILED;
    }
    int recvSize = TcpRecvData(session->fd, recvDataBuf, size + OVERHEAD_LEN, 0);//接收TCP数据保存在recvDataBuf中,预读取size + OVERHEAD_LEN的数据量,返回实际读到的数据量
    if (recvSize < TRANS_PACKET_HEAD_SIZE) {
        FreeSessionRecvMem(recvDataBuf, session);
        return TRANS_FAILED;
    }
    long long seq = 0;
    AesGcmCipherKey cipherKey = {0};
    cipherKey.keybits = GCM_KEY_BITS_LEN_256;//采用256位的密钥加解密
    int ret = memcpy_s(&seq, SIZE_OF_LONG_LONG, recvDataBuf + TRANS_SEQ_NUM_OFFSET, SIZE_OF_LONG_LONG);//获取数据包的序列号
    ret += memcpy_s(cipherKey.key, SESSION_KEY_LENGTH, session->sessionKey, SESSION_KEY_LENGTH);//赋予会话密钥
    ret += memcpy_s(cipherKey.iv, IV_LEN, recvDataBuf + TRANS_PACKET_HEAD_SIZE, IV_LEN);//赋予会话iv值
    if (ret != 0) {
        FreeSessionRecvMem(recvDataBuf, session);
        return TRANS_FAILED;
    }
    SessionSeqNumNode* node = calloc(1, sizeof(SessionSeqNumNode));
    if (node == NULL) {
        FreeSessionRecvMem(recvDataBuf, session);
        return TRANS_FAILED;
    }
    node->seqNum = seq;//赋予数据包序列号
    ListInsertTail(session->seqNumList, &(node->head));//将该数据包序列号节点插入seqNumList链表尾部
    int plainLen = DecryptTransData(&cipherKey, (unsigned char*)(recvDataBuf + TRANS_PACKET_HEAD_SIZE),
        recvSize - TRANS_PACKET_HEAD_SIZE, (unsigned char*)buf, size);//解密传输数据,解密后的明文保存在buf中
    free(recvDataBuf);
    if (plainLen <= 0) {
        return TRANS_FAILED;
    }
    return plainLen;
}
相关推荐
掘金-我是哪吒1 小时前
分布式微服务系统架构第128集:elastic-search安装部署
分布式·微服务·云原生·架构·系统架构
.生产的驴6 小时前
SpringBoot 集成滑块验证码AJ-Captcha行为验证码 Redis分布式 接口限流 防爬虫
java·spring boot·redis·分布式·后端·爬虫·tomcat
小森77676 小时前
(九)PMSM驱动控制学习---分流电阻采样及重构
stm32·嵌入式·电机控制·foc·永磁同步电机·pmsm·电流采样
FreakStudio8 小时前
一文速通Python并行计算:10 Python多进程编程-进程之间的数据共享-基于共享内存和数据管理器
python·嵌入式·多线程·多进程·线程同步
weixin_4373982110 小时前
RabbitMQ深入学习
java·分布式·后端·spring·spring cloud·微服务·rabbitmq
心碎土豆块10 小时前
hadoop的运行模式
大数据·hadoop·分布式
2301_7807896610 小时前
高防ip是怎么做到分布式防御的
分布式·网络协议·tcp/ip·游戏·ddos·高防ip·高防cdn
搏博12 小时前
软件工程之形式化说明技术深度解析
分布式·软件工程·软件构建·软件需求
bestadc13 小时前
鸿蒙 所有API缩略图鉴
harmonyos
XQ丶YTY14 小时前
记录一下学习kafka的使用以及思路
分布式·学习·kafka