今天给大家介绍一下小程序配网工具-安信可 IOT,近期刚发布了新的版本,新增了服务器地址配置的功能。 可以说这个新功能,给我们带来了不少便利,特别是 HomeAssistant 固件使用这一块。 2024 年 7 月 17 号之前,安信可 IOT 小程序只能给大家提供配网程序,大家能够利用蓝牙功能给 WiFi 模块进行无线网络配置,但是随着 DIY 作品不断地更新,发现要给大家更加方便地使用固件地话,涉及 TCP 服务器和 MQTT 服务器地址配置只能通过 AT 指令来实现,在某些应用场合根本无法实现。
所以,就让前端工程师加了这个功能,在配网的时候,可以选择配置服务器地址
新功能介绍
新功能使用说明
数据格式
小程序下发的服务器配置数据是以 json 格式下发:
代码语言:javascript复制{
"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 头文件,就能实现对服务器地址和端口号的解析,下面写了函数,大家做个参考
解析服务器地址
代码语言:javascript复制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=%srn",addr);
解析端口号
代码语言:javascript复制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=%drn",port);