安信可IOT 微信小程序
今天水一篇帖子,给大家介绍一下小程序配网工具-安信可IOT,昨天刚发布了新的版本,新增了服务器地址配置的功能。
可以说这个新功能,给我们带来了不少便利,特别是HomeAssistant固件使用这一块。
昨天(2024年7月17号)之前,安信可IOT小程序只能给大家提供配网程序,大家能够利用蓝牙功能给WiFi模块进行无线网络配置,但是随着DIY作品不断地更新,发现要给大家更加方便地使用固件地话,涉及TCP服务器和MQTT服务器地址配置只能通过AT指令来实现,在某些应用场合根本无法实现。
所以,就让前端工程师加了这个功能,在配网的时候,可以选择配置服务器地址
新功能介绍
新功能使用说明

数据格式
小程序下发的服务器配置数据是以json格式下发:
{
    "server_type":
    {
        "addr":"0.0.0.0",
        "port":"xxxxx"
    }
}
| 字段名 | 说明 | 示例 | 
| server_type | 服务器类型 | "tcp" | 
| addr | 服务器地址,支持IPV4地址和域名 | "192.168.1.1" | 
| port | 服务器端口号 | 1883 | 
例如:下发一个TCP服务器,地址为:192.168.3.1,端口号为:8888,则数据为:
{
   "tcp":
   {
       "addr":"192.168.3.1",
       "port":"8888"
   }
}
数据接收
数据接收就是设备端的了,但是前提是要使用Blufi 配网功能,在Ai-WB2的SDK(Ai-Thinker-WB2)当中,有Blufi的demo。

因为小程序下发的数据是通过Blufi的custom data(自定义数据)接口下发,在blufo demo当中的AXK_BLUFI_EVENT_RECV_CUSTOM_DATA事件,可以看到下发的服务器地址数据:

数据解析
既然是json 数据,那只要引用cJSON.h 头文件,就能实现对服务器地址和端口号的解析,下面写了函数,大家做个参考
解析服务器地址
static char data_buff[128] = { 0 };
char* get_ip_addr_from_custom_data(const char* server_type, const char* custom_data)
{
    if (custom_data==NULL) {
        blog_error("custom_data is NULL");
        return NULL;
    }
    char* cjson_root = custom_data;
    cJSON* root = cJSON_Parse(cjson_root);
    if (root==NULL)
    {
        blog_error("%s is't json data", cjson_root);
        cJSON_Delete(root);
        return NULL;
    }
    cJSON* add_type = cJSON_GetObjectItem(root, server_type);
    if (add_type==NULL)
    {
        blog_error("%s not \"%s\" project ", cjson_root,server_type);
        cJSON_Delete(root);
        return NULL;
    }
    cJSON* addr = cJSON_GetObjectItem(add_type, "addr");
    if (addr==NULL)
    {
        blog_error("%s not \"addr\" project ", cjson_root);
        cJSON_Delete(root);
        return NULL;
    }
    memset(data_buff, 0, 128);
    strcpy(data_buff, addr->valuestring);
    cJSON_Delete(root);
    return data_buff;
}
| 函数说明 | 说明 | 示例 | 
| server_type | 服务器类型,支持以下类型:tcp、udp和mqtt | "tcp" | 
| custom_data | blufi 接收自定义数据 | / | 
| 返回值:char* | 返回服务器地址的指针 | / | 
调用示例:
char* addr=get_ip_addr_from_custom_data("tcp",custom_data);
printf("addr=%s\r\n",addr);
解析端口号
uint16_t get_port_from_custom_data(const char* server_type, const char* custom_data)
{
    if (custom_data==NULL) {
        blog_error("custom_data is NULL");
        return NULL;
    }
    char* cjson_root = custom_data;
    cJSON* root = cJSON_Parse(cjson_root);
    if (root==NULL)
    {
        blog_error("%s is't json data", cjson_root);
        cJSON_Delete(root);
        return NULL;
    }
    cJSON* add_type = cJSON_GetObjectItem(root, server_type);
    if (add_type==NULL)
    {
        blog_error("%s not \"%s\" project ", cjson_root,server_type);
        cJSON_Delete(root);
        return NULL;
    }
    cJSON* port_p = cJSON_GetObjectItem(add_type, "port");
    if (port_p==NULL)
    {
        blog_error("%s not \"port\" project ", cjson_root);
        cJSON_Delete(root);
        return NULL;
    }
    uint16_t port = atoi(port_p->valuestring);
    cJSON_Delete(root);
    return port;
}
| 函数说明 | 说明 | 示例 | 
| server_type | 服务器类型,支持以下类型:tcp、udp和mqtt | "tcp" | 
| custom_data | blufi 接收自定义数据 | / | 
| 返回值:uint16_t | 返回端口号,范围:0-65535 | 1883 | 
调用示例:
uint16_t port=get_port_from_custom_data("tcp",custom_data);
printf("port=%d\r\n",port);
这些程序流程我就不解释,太简单了,不懂的话,自己去学一下cjson的数据解析