OpenHarmony深度解读之分布式软总线:authmanager模块(6)/设备身份认证过程

📌往期推文全新看点(文中附带最新·鸿蒙全栈学习笔记)

①📖 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?

②📖嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~

③📖 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?

④📖 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?

⑤📖 记录一场鸿蒙开发岗位面试经历~

⑥📖 持续更新中……


一、概述

本文将继续分析设备之间的身份认证过程的相关细节,主要是针对数据包类型为MODULE_CONNECTION的处理过程。主要源代码在wifi_auth_manager.c文件的函数OnModuleMessageReceived()中。

二、源码分析

  1. 如果数据包类型为MODULE_CONNECTION,首先调用OnMessageReceived()函数。处理接收到的消息,解析并按规则回复给对端。
/*
函数功能:处理接收到的消息,解析并按规则回复给对端
函数参数:
    conn:设备连接信息
    seq:数据包序列号
    msg:cJSON格式的数据包负载消息
函数返回值:无
详细:
*/
void OnMessageReceived(AuthConn *conn, long long seq, const cJSON *msg)
{
    if (conn == NULL || msg == NULL) {
        return;
    }
    SOFTBUS_PRINT("[AUTH] OnMessageReceived begin\n");
    cJSON *codeJson = cJSON_GetObjectItem(msg, "CODE");//获取json指定的对象成员"CODE"
    if ((codeJson == NULL) || (!cJSON_IsNumber(codeJson))) {//判断codeJson是否为数字类型的成员,如果不是,就直接返回
        return;
    }
    int code = codeJson->valueint;//取出json中的值
    switch (code) {
        case CODE_VERIFY_IP: {
            OnVerifyIp(conn, seq, msg);//处理"验证IP"请求消息并回复对端
            break;
        }
        case CODE_VERIFY_DEVID: {
            OnVerifyDeviceId(conn, seq, msg);//处理"验证DeviceId"请求消息并回复对端
            break;
        }
        default:
            break;
    }
}
  1. 然后在函数OnMessageReceived中,根据解析出来的json数据的CODE字段继续进行处理。如果CODE字段为CODE_VERIFY_IP,则调用OnVerifyIp()函数进行处理。
/*
函数功能:处理"验证IP"请求消息并回复对端
函数参数:
    conn:认证连接信息
    seq:数据包序列号
    request:请求消息的内容
函数返回值:无
详细:
*/
void OnVerifyIp(AuthConn *conn, long long seq, const cJSON *request)
{
    if (conn == NULL || request == NULL) {
        return;
    }
    DeviceInfo *localDevInfo = BusGetLocalDeviceInfo();//获取本地设备信息
    if (localDevInfo == NULL) {
        return;
    }
    ConnInfo connInfo = {0};
    connInfo.maxVersion = BUS_V2;//总线版本
    connInfo.minVersion = BUS_V2;
    int ret = MsgVerifyIpUnPack(request, &connInfo, conn);//解析请求消息,更新普通连接信息结构体和认证连接结构体
    if (ret != 0) {
        return;
    }
    cJSON *reply = MsgVerifyIpPack(&connInfo, localDevInfo, g_authPort, g_sessionPort);//构造回复验证IP的消息
    if (reply == NULL) {
        return;
    }
    ret = AuthConnPostMessage(conn->fd, MODULE_CONNECTION, FLAG_REPLY, seq, reply);//构造/封装身份认证Post消息并发送给对端,MODULE_CONNECTION表示请求认证连接(暂定)
    cJSON_Delete(reply);
    reply = NULL;
    if (ret != 0) {
        return;
    }
    conn->onlineState = ONLINE_YES;//将该认证连接的在线状态改为:在线
    SOFTBUS_PRINT("[AUTH] OnVerifyIp ok\n");
}
  1. 如果CODE字段为CODE_VERIFY_DEVID,则调用OnVerifyDeviceId()函数进行处理。
/*
函数功能:处理"验证DeviceId"请求消息并回复对端
函数参数:
    conn:认证连接信息
    seq:数据包序列号
    request:请求消息的内容
函数返回值:无
详细:
*/
void OnVerifyDeviceId(const AuthConn *conn, long long seq, const cJSON *request)
{
    if (conn == NULL || request == NULL) {
        return;
    }
    char *deviceId = GetJsonString(request, "DEVICE_ID");//获取消息中的设备id
    if (deviceId == NULL) {
        return;
    }
    DeviceInfo *info = BusGetLocalDeviceInfo();//获取本地设备信息
    if (info == NULL) {
        return;
    }
    cJSON *reply = MsgVerifyDeviceIdPack(info);//打包"验证DeviceId"回复消息,封装成cJSON格式的回复消息
    if (reply == NULL) {
        return;
    }
    (void)AuthConnPostMessage(conn->fd, MODULE_CONNECTION, FLAG_REPLY, seq, reply);//构造/封装身份认证Post消息并发送给对端,MODULE_CONNECTION表示请求认证连接(暂定)
    cJSON_Delete(reply);
    reply = NULL;
    SOFTBUS_PRINT("[AUTH] OnVerifyDeviceId ok\n");
    return;
}

至此,设备之间的身份可信认证过程基本结束。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值