作者:哈猪猪
前言
本系列共有三篇文章,目的是在 RVB2601 上实现基于 HTTPClient 组件的云语音识别。文章连接与主要内容如下:
- 文章1:设计思路;HTTPClient 组件测试
- 文章2:HTTPClient 组件源码解析
- 文章3:手动实现“multipart/form-data”类型 POST 请求;完成板端与服务器端代码,实现整个云语音识别功能。
设计思路
RVB2601 板载资源非常丰富,支持 WiFi、蓝牙、Codec、麦克风等,因此我们能够通过这块开发板实现绝大部分物联网场景下的应用,如云语音识别。
在官方提供的 RVB2601 示例程序中:ch2601_ft_demo 实现了麦克风录音并由扬声器回放的功能;ch2601_webplayer_demo 实现了从网络上下载音乐并播放的功能。因此我们有理由相信借助于现有的组件就能够实现一个基于 Http 的云语音识别。
然而,ch2601_webplayer_demo 中使用的网络库并不提供完整的 HTTP 功能,因此我们需要寻找支持 RVB2601 的其它网络库。
通过上网搜寻,找到了 平头哥YOC文档,里面列举了众多 API 以及模块组件;以及对应的 YOC github 源码。
其中,YOC 提供一个网络组件:HTTPClient,它“为http/https客户端组件,为用户提供一组简洁的调用接口。”并且看其接口列表它好像还实现了 HTTP 的各种请求(年轻了)。
因此我们选择使用 HTTPClient 组件来帮助我们与服务器通信,上传录音文件并接收识别结果。
HTTPClient 组件测试
由于这是一个没有出现在 RVB2601 示例程序中的组件,我们还不清楚能否使用以及如何使用。所幸源码中提供了 HTTPClient 的测试程序:http_examples。因此我们可以先尝试测试该组件。
项目工程建立在 ch2601_webplayer_demo 上。以下为操作流程:
项目配置
首先从 YOC github 源码下载所需组件,除了 HTTPClient 外还需要 transport 组件。
接着进入 CDK 工程,右键 Packages 并新建一个普通包:
设置包名以及存储路径:
接着我们就能向刚刚新建的 Package 里添加下载的源码:
最后我们需要对 Package 进行配置:
在 Compiler 选项卡中设置 Include:
最后在 Base 选项卡中编辑 Description:
源码修改
我们直接将 http_examples.c 的内容加入到 player_demo.c 中,并向 CLI 控制台注册一个新命令 http_test:
/* player_demo.c */ static void cmd_http_func(char *wbuf, int wbuf_len, int argc, char **argv) { if (argc == 1 && strcmp(argv[0], "http_test") == 0) { test_https(); } else printf("\thttp_test\n"); } int cli_reg_cmd_player(void) { ... static const struct cli_command http_cmd_info= { "http_test", "http_test", cmd_http_func, }; aos_cli_register_command(&cmd_info); ... return 0; }
这样,当控制台接收到 http_test 命令后就会直接调用 http_examples.c 中的测试函数 test_https()。
测试后没有什么问题,因此我们能够在 RVB2601 上调用 HTTPClient 提供的接口,来帮助我们与服务器通信。
本文源自:平头哥芯片开放社区
欢迎关注公众号:芯片开放社区(ID:OCC_THEAD),查看更多应用实战文章。