前言

本文介绍什么是CoAP,以及如何在物联网设备上使用它。CoAP是一种物联网协议,具有一些专门为受约束的设备而设计的有趣功能。还有其他一些可用于构建物联网解决方案的IoT协议,例如MQTT等。

物联网是最有趣和最有前途的技术趋势之一。在这个生态系统中,对象,人员,设备相互连接并交换数据。在此博客中,我们从多个角度介绍了物联网和开发物联网项目,并涵盖了与物联网相关的多个方面。

什么是CoAP协议?

如前所述,CoAP是一种物联网协议。CoAP意思为Constrained Application Protocol,在RFC 7252中所定义。CoAP是一种低开销的简单协议,专门针对受限设备(例如微控制器)和受限网络而设计。该协议用于M2M数据交换中,并且与HTTP非常相似,即使稍后我们将介绍重要的区别。

CoAP协议的主要特征是:

  • 受限制的小型设备的Web传输协议(类似于HTTP)
  • 异步消息交换
  • 低开销,非常易于解析
  • URI和内容类型支持
  • 代理和缓存功能

您可能会注意到,CoAP某些功能也与HTTP非常相似,但是不能将CoAP视为压缩版本的HTTP协议,因为CoAP是专门为IoT设计的,并且更详细地针对M2M,因此针对这些要求必须有所优化。

从抽象协议层,CoAP可以表示为:

正如你所看到的,CoAP协议有两个不同的层:消息负载请求/响应。消息层处理UDP和异步消息。请求/响应层基于请求/响应消息来管理请求/响应交互。

CoAP支持四种不同的消息类型:

  • 可确认的 Confirmable(CON)
  • 无法确认 Non-confirmable(NON)
  • 确认 Acknowledgment
  • 重置 Reset

在深入研究CoAP协议之前,以下必要的术语有助于我们更好的了解CoAP协议:

  • 节点(Endpoint):参与CoAP协议的实体。通常,将端点标识为主机
  • 发件人(Sender):发送消息的实体
  • 收件人(Recipient):接受消息的实体
  • 客户端(Client):发送请求的实体和接受消息的实体
  • 服务器(Server):接收来自客户端的请求并向客户端发送回响应的实体

CoAP消息模型

这是CoAP的最低层。该层处理端点之间的UDP交换消息。每个CoAP消息都有一个唯一的ID。这对于检测消息重复很有用。CoAP消息由以下部分构建:

  • 二进制标志头
  • 可选项
  • 载荷消息

稍后,我们将更详细地描述消息格式。

如前所述,CoAP协议使用两种消息:

  • 确认消息
  • 不可确认的消息

可确认消息是可靠消息。在两个端点之间交换消息时,这些消息可能是可靠的。在CoAP中,使用确认消息(CON)获得可靠的消息。使用这种消息,客户端可以确保消息将到达服务器。反复发送确认消息,直到另一方发送确认消息(ACK)。ACK消息包含与确认消息(CON)相同的ID。

下图显示了消息交换过程:

如果服务器在管理传入请求时遇到问题,则可以发送回Rest消息(RST)而不是Acknowledge消息(ACK):

另一个消息类别是“不可确认(NON)”消息。这些是不需要服务器确认的消息。它们是不可靠的消息,或者换句话说,这些消息不包含必须传递给服务器的关键信息。包含从传感器读取的值的消息属于此类别。

即使这些消息不可靠,它们也具有唯一的ID。

CoAP请求/响应模型

CoAP请求/响应是CoAP抽象层中的第二层。使用“确认”(CON)或“非确认”(NON)消息发送请求。根据服务器是否可以立即响应客户端请求或答案(如果不可用),有几种方案。

如果服务器可以立即响应客户端请求,则如果使用确认消息(CON)承载了请求,则服务器将包含响应或错误代码的确认消息发送回客户端:

如您在CoAP消息中所注意到的,有一个令牌。令牌不同于消息ID,它用于匹配请求和响应。

如果服务器无法立即响应来自客户端的请求,则它将发送带有空响应的确认消息。一旦响应可用,服务器就会向客户端发送一条新的Confirmable消息,其中包含响应。此时,客户端发送回确认消息:

如果来自客户端的请求是使用不可确认消息承载的,则服务器将使用不可确认消息进行应答。

CoAP消息格式

本段涵盖了CoAP消息格式。到目前为止,我们已经讨论了客户端和服务器之间交换的各种消息。现在是时候分析消息格式了。受限的应用程序协议是受限环境中的关键,因此,它使用紧凑的消息。为了避免分段,消息占用UDP数据报的数据部分。一条消息由几个部分组成:

Version(VER)(2 bits): CoAP版本号

Type(2 bits)

​ 这描述了请求和响应着两种消息类型上下文的数据包消息类型。

  • 请求

    • 0 : 可确认: 该消息需要相应的确认消息。
    • 1 : 不可确认:此消息不需要确认消息。
  • 响应
    • 2 : 确认: 此消息是确认可确认消息的响应。
    • 3 : 重置: 此消息表明它已收到消息,但无法处理。

Token Length(4 bits): 指示可变长度令牌字段的长度,其长度可以为0-8字节。

Request/Response(8 bits): CoAP请求/响应代码

Message ID(16 bits): 用于检测消息重复并将“确认/重置”类型的消息与“确认” /“不可确认”类型的消息进行匹配。:响应消息将具有与请求相同的消息ID。

CoAP安全方面

处理物联网协议时的一个重要方面是安全性方面。如前所述,CoAP使用UDP传输信息。CoAP依靠UDP安全性方面来保护信息。由于HTTP使用基于TCP的TLS,因此CoAP使用基于UDP的数据报TLS。DTLS支持RSA,AES等。无论如何,我们应该考虑在某些受限设备中可能无法使用某些DTLS密码套件。重要的是要注意,某些密码套件引入了一些复杂性,并且受约束的设备可能没有足够的资源来管理它。

相关物联网技术指导更新于: https://github.com/IoT-Technology/IOT-Technical-Guide

初识CoAP协议的更多相关文章

  1. 初识HTTP协议

    本篇文章从概念上初识HTTP协议,参考链接:http://www.runoob.com/http/http-tutorial.html 目录: 一.HTTP协议    HTTP 工作原理    HTT ...

  2. 转:XMPP协议、MQTT协议、HTTP协议、CoAP协议的基本比较

    一.先看下相关国外的专业数据对四大协议的比较: Protocol                                    CoAP                         XMP ...

  3. CoAP 协议解析说明(转)

    CoAP 协议全面分析 HTTP与COAP 请求与响应示例 HTTP请求(文本格式) POST https://getman.cn/echo HTTP/1.1 User-Agent: Fiddler ...

  4. Coap协议学习笔记-第一篇

    1. 物联网应用上一般使用单片机(或者其他SOC),单片机的RAM内存一般只有20KB~~128KB左右,然而一个TCP协议栈可能就20KB,所以只能用UDP,因为UDP相对小很多,然后在UDP上加了 ...

  5. Android之Http通信——1.初识Http协议

    Android之Http通信--1.初识Http协议 引言: 今天是六一儿童节,先在这里给各位超龄儿童说声节日快乐哈~( ╯□╰ ),小猪也象征性地给群里的小朋友们派了红包-嗯,忙碌的五月最终过去了, ...

  6. 无线物联网中CoAP协议的研究与实现【转】

    无线物联网中CoAP协议的研究与实现 时间:2013-04-09 来源:电子科技 作者:汤春明,张 荧,吴宇平 关键字:CoAP   无线   物联网   协议 摘要:由于物联网中的很多设备都是资源受 ...

  7. 转战物联网·基础篇09-选择MQTT协议还是CoAP协议

      前面章节介绍过,MQTT协议和CoAP协议都是物联网中比较流行的协议,都对传输量做了很大的精简,传输开销小,以适应物理网的网络环境.   XMPP协议也有人说是适合物联网通信的,但它是基于XML, ...

  8. MQTT研究之EMQ:【CoAP协议应用开发】

    本博文的重点是尝试CoAP协议的应用开发,其中包含CoAP协议中一个重要的开源工具libcoap的安装和遇到的问题调研.当然,为了很好的将EMQ的CoAP协议网关用起来,也调研了下EMQ体系下,CoA ...

  9. MQTT研究之EMQ:【CoAP协议的ECC证书研究】

    今天研究的内容,是CoAP这个协议在EMQ消息队列的支持,CoAP是一个受限资源的协议,基于UDP实现的多用于物联网环境的通信协议.相关介绍不多说,可以看RFC. CoAP协议下,基于DTLS通信,同 ...

随机推荐

  1. app扫描二维码登陆

    先说明一下实现原理: 如同微信扫描登陆一样,就是一种pc的自动登陆授权.在网站首页得有切换登陆的选项:密码登陆 扫码登陆 当用户切换到扫码登陆时,向服务器请求一次获得一个唯一的uukey 利用这个uu ...

  2. jvm入门及理解(四)——运行时数据区(堆+方法区)

    一.堆 定义: Heap,通过new关键字创建的对象,都存放在堆内存中. 特点 线程共享,堆中的对象都存在线程安全的问题 垃圾回收,垃圾回收机制重点区域. jvm内存的划分: JVM内存划分为堆内存和 ...

  3. golang trace 分析 简例

    今天,通过一个例子,一方面熟悉trace在自定义范围内的分析,另一方面golang 在协程调度策略上的浅析. Show Code // trace_example.go package main im ...

  4. QMS产品 - MasterControl 质量管理活动

    主要质量管理活动如下所示: CAPA 纠正措施/预防措施 Corrective Maintenance 纠正措施 Preventive Maintenance 预防措施 Customs Complai ...

  5. 小程序运行时如何助力传统APP转型?

    小程序和H5或者RN有什么区别?优越性在哪里? 长期以来,移动互联网界一直在寻找一种既能获得Native原生的体验,又可以低门槛快速开发的技术.在这个过程中出现了很多尝试,例如React Native ...

  6. Connections in Galaxy War ZOJ - 3261 (并查集)

    点权并查集的反向离线操作 题目大意:有n个stars,每一个都一定的“颜值”.然后stars与stars之间可以相连,query c表示再与c相连的stars中,颜值比c高的,stars的标号,如果有 ...

  7. A - Number Sequence 哈希算法(例题)

    Given two sequences of numbers : a[1], a[2], ...... , a[N], and b[1], b[2], ...... , b[M] (1 <= M ...

  8. Wireshark的两种过滤器与BPF过滤规则

    Wirshark使用的关键就在于过滤出想要的数据包,下面介绍怎么过滤. 抓包过滤器 Wirshark有两种过滤器,一个是抓包过滤器,一个是显示过滤器,他们之间的区别在于抓包过滤器只抓取你设置的规则,同 ...

  9. 12. 前后端联调 + ( proxy代理 ) + ( axios拦截器 ) + ( css Modules模块化方案 ) + ( css-loader ) + ( 非路由组件如何使用history ) + ( bodyParser,cookieParser中间件 ) + ( utility MD5加密库 ) + ( nodemon自动重启node ) + +

    (1) proxy 前端的端口在:localhost:3000后端的端口在:localhost:1234所以要在webpack中配置proxy选项 (proxy是代理的意思) 在package.jso ...

  10. 3. JS生成32位随机数

    function randomWord ( randomFlag,min,max ) { var str = " ", range = min, arr = ['0','1','2 ...