嵌入式linux实现http交互,【开源】彻底解决嵌入式HTTP客户端的痛点

介绍了一个开源的高性能、跨平台HTTP客户端库,提供极简API接口,只需1行代码即可进行GET和POST操作。该库支持多种操作系统,包括自动选择TCP或TLS加密传输,并具有稳定性和高效性。文档齐全,适合嵌入式开发和跨平台应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原标题:【开源】彻底解决嵌入式HTTP客户端的痛点

你还在 自己写HTTP协议吗?

你还在 找好用的HTTP客户端吗?

你还在用 难以移植的HTTP客户端吗?

你还在 苦逼的移植安全加密库吗?

你还在用 难用的API接口吗?

你还 …..

高性能、跨平台的HTTP客户端

今天,它它它它它它来了,解决所有的 痛点, 一个高性能,跨平台的HTTP客户端,今天发布了,拥有 极简的API接口,你知道吧,仅需要 1行代码就能请求一个URL资源(我说的 1行并不是你们所想的最后套一个函数, 而是在绝大部分的情况下都可以使用的API接口),一个对开发者及其友好的接口,用起来就是舒服,跨平台移植轻而易举。

你可以很轻易让他跑在Linux、FreeRTOS、RT-Thread、TencentOS tiny等操作系统平台上,很轻松通过它去下载文件、请求HTTP服务器的数据,甚至是安全管理的加密协议你也不需要考虑,因为这个HTTP客户端会自动选择数据通道,无论是TCP还是TLS加密传输。

看到这里,你还感兴趣的话,请往下看。。。

HTTP客户端整体架构

732fd22f63685042017cbde1305e223f.png

介绍一下整个架构的思想:

最上方是对外的 API 接口,实现了基本的HTTP操作,如GET/POST等。

接着就是 client管理器 ,通过 池化 技术实现了 client pool ,在使用的时候从池中取出 client ,用完就放回,用户基本不需要直接接触 client 实例,实现了基本的 HTTP方法 ,如 GET/POST 等,还实现了 url解析器 ,解析用户传入的 ur l ,生成合适的参数递交给拦截器。

实现 工作队列 ,进行异步处理,在 CPU 支持多核的情况下,根据 CPU 的最大支持线程数量创建多个线程处理,将所有来自上层的请求按顺序放入工作队列,并行处理。

intercept 是拦截器,比如实现 HTTP请求 、 HTTP应答 等,它需要依赖 HTTP 报文的处理。拦截器的主要的处理工作是通过上层传入的参数去设置网络信息( host、port 等),与服务器 建立连接 、 重连 , 发起HTTP请求 、 解析来自服务器的响应报文 , 自动处理重定向 、 身份验证 及其他 操作,而保证这些操作能完成的需要基础组件,通用的 字符串处理 、 事件的回调处理 、 HTTP 的通用信息等,最下方的 read and write 则是与 network 打交道的。

network 是网络组件,它可以自动选择数据通道,如果是 加密 方式则通过 tls 进行数据传输,而 tls 可以选择 mbedtls 作为加密后端也可以选择 openssl 作为加密后端, 它是自动选择数据通道的 ;也可以是 tcp 直连方式,最终都是通过 tcp 传输的,此外还实现了本地的 routing (或者叫 dns 缓存,加快域名的解析处理)。

platform 是平台抽象层,封装了不同系统的东西,比如 socke 或者 AT,线程、时间、互斥锁、内存管理 ,这些是与系统打交道的,也是跨平台必要的封装。

最右边的则是 通用 的处理, list 列表的处理、 日志库、错误代码、软件随机数发生器 等。

优势

高性能、跨平台、极简的API接口与稳定性。

首先,高性能是因为使用了Node.js的底层解析库,众所周知Node.js是一个非常高性能的服务端Java环境,而它的底层解析HTTP协议是用的C语言实现的 超高性能的解析库 ,在目前看来应该是 举世无双 了。

跨平台是因为我自己实现了 平台的抽象层 ,可以跑在不同的系统之中,它不像 wget、curl 一样,仅限于Linux平台。

极简的API接口,如果你要GET一个文件或者请求一个URL资源,1行代码就够了,至于为什么, 请看我上面介绍的架构实现 ,用池化技术实现管理所有的 client池 ,非常简洁,举个例子:

GET操作( ps :_http_cb是返回的数据内容的回调函数,直接读取数据就行了,你啥都不用管)

http_client_get( "http://www.jiedev.com", _http_cb);

POST操作(直接指定URL,POST的数据内容,_http_cb是返回的数据内容,当然也可以为NULL)

http_client_post( "http://httpbin.org/post", "this is a post test ...", _http_cb);

稳定性,目前曾多次测试,都是很稳定的,数据不会丢失,获取 109M 的文件内容, 重定向测试 、都是非常好的,具体可以看后续的例子。

文档说明

当然啦,作为一个开源软件,文档的介绍是必不可少的,作者写了很多的 文档介绍,所有的功能实现都有详细的文档介绍,每个组件有什么功能都列举出来了,你可以看到它是怎么实现的,如果你想学习源码的话,通过这些文档,你可以非常快速了解整个架构的实现。

ps:这些文档都在github项目主页中。

c2d9078868323669e734eaf612fa739a.png

开发历程

在github是可以看到作者写的功能的需求,希望让大家参与进来的,所以写了开发计划的文档,并且不断完善它,很庆幸基本上所有的功能都已经实现了,当然后续还好持续添加新的功能,并且不断维护这个项目,所有的功能实现如下:

27037375583ebdc6a161c25f22225043.png

7def405ac9f18d918f9a034d7d4d1080.png

52b1d1102a5d090a5b75971736e0297b.png

测试的效果

这些是GIF动态图,可以欣赏一下性能~

URL解析,性能杠杠的,不愧为超高性能的解析库

a15565fe23fac866c0c46e12bf778e74.gif

GET请求数据

8e289ce9fddec336392ecb7d2a9f5e5e.gif

POST数据到服务器

d26b4ced174e837ddc0040cdf42ef242.gif

自动处理重定向

d35882346b44a93a399f097e74e65ab7.gif

下载109M的文件,性能真的杠杠的

f41408b3cbb6aca784edfbfb46f5c6c9.gif

http://club.digiic.com/Forum/PostDetail/p-22601.html返回搜狐,查看更多

责任编辑:

NanoHTTPD是一个免费、轻量级的(只有一个Java文件) HTTP服务器,可以很好地嵌入到Java程序中。支持 GET, POST, PUT, HEAD 和 DELETE 请求,支持文件上传,占用内存很小。可轻松定制临时文件使用和线程模型。NanoHTTPD for JDK 1.1https://github.com/NanoHttpd/nanohttpd/tree/nanohttpd-for-java1.1示例代码:package fi.iki.elonen.debug;   import fi.iki.elonen.NanoHTTPD; import fi.iki.elonen.ServerRunner;   import java.util.HashMap; import java.util.List; import java.util.Map;   public class DebugServer extends NanoHTTPD {     public DebugServer() {         super(8080);     }       public static void main(String[] args) {         ServerRunner.run(DebugServer.class);     }       @Override public Response serve(IHTTPSession session) {         Map<String, List<String>> decodedQueryParameters =             decodeParameters(session.getQueryParameterString());           StringBuilder sb = new StringBuilder();         sb.append("<html>");         sb.append("<head><title>Debug Server</title></head>");         sb.append("<body>");         sb.append("<h1>Debug Server</h1>");           sb.append("<p><blockquote><b>URI</b> = ").append(             String.valueOf(session.getUri())).append("<br />");           sb.append("<b>Method</b> = ").append(             String.valueOf(session.getMethod())).append("</blockquote></p>");           sb.append("<h3>Headers</h3><p><blockquote>").             append(toString(session.getHeaders())).append("</blockquote></p>");           sb.append("<h3>Parms</h3><p><blockquote>").             append(toString(session.getParms())).append("</blockquote></p>");           sb.append("<h3>Parms (multi values?)</h3><p><blockquote>").             append(toString(decodedQueryParameters)).append("</blockquote></p>");           try {             Map<String, String> files = new HashMap<String, String>();             session.parseBody(files);             sb.append("<h3>Files</h3><p><blockquote>").                 append(toString(files)).append("</blockquote></p>");         } catch (Exception e) {             e.printStackTrace();         }           sb.append("</body>");         sb.append("</html>");         return new Response(sb.toString());     }       private String toString(Map<String, ? extends Object> map) {         if (map.size() == 0) {             return "";         }         return unsortedList(map);     }       private String unsortedList(Map<String, ? extends Object> map) {         StringBuilder sb = new StringBuilder();         sb.append("<ul>");         for (Map.Entry entry : map.entrySet()) {             listItem(sb, entry);         }         sb.append("</ul>");         return sb.toString();     }       private void listItem(StringBuilder sb, Map.Entry entry) {         sb.append("<li><code><b>").append(entry.getKey()).             append("</b> = ").append(entry.getValue()).append("</code></li>");     } } 标签:NanoHTTPD
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值