GATT两个角色 服务器与客户端
两个设备应用数据的通信是通过协议栈的GATT层实现的。
从GATT角度来看,当两个设备建立连接后,他们处于以下两种角色之一:
GATT服务器: 它是为GATT客户端提供数据服务的设备
GATT客户端: 它是从GATT服务器读写应用数据的设备
GATT角色中的客户端和服务器的概念与链路层的主机和从机的概念完全独立,与GAP角色中的外设和集中器的概念也是完全独立的。主机既可以是GATT客户端,也可以是GATT服务器;从机既可以是GATT客户端,也可以是GATT服务器。
一个GATT服务器中可包含一个或多个GATT服务,GATT服务是完成特定功能的一系列数据的集合。在SimpleBLEPeripheral应用中有三个GATT服务。
1、强制的GAP服务。这一服务包含了设备的访问信息,如设备名,设备供应商和产品标识。它是协议栈的一部分,是BLE规范对每一个BLE设备的强制要求。
2、强制的GATT服务。这一服务包含了GATT服务器的信息,是协议栈的一部分,是BLE规范对每一个BLE设备的要求。
3、SimpleGATTProfile服务。这个服务包含了应用数据的信息,与应用数据的传递密切相关,可按照特定的格式编写自己的GATT服务。
特性Characetristics是服务用到的值,以及其内容和配置信息。GATT定义了在BLE连接中发现、读取和写入属性的子过程。GATT服务器上的特性值极其内容和配置信息(称为描述符)存储在属性表中。属性表是一个数据库,包含了成为属性的小块数据,除了值本身,每个属性都包含了下列属性:
1、句柄。属性表中的地址,每个属性有唯一的句柄;
2、类型。表示数据代表的事物,通常是SIG规定或由用户自定义的UUID(UniversallyUnique Identifier);
3、权限。规定了GATT客户端设备对属性的访问权限,包括是否能访问和怎样访问。
GATT定义了若干GATT服务器和客户端之间通信的子过程:
1、读特性值。客户端设备请求读取句柄处的特性值,服务器将此值回应给客户端(假定属性有读取权限)。
2、使用特性的UUID读。客户端请求读基于一个特定类型的所有特征值,服务器将所有与指定类型匹配的特性的句柄和值返回给客户端设备(假定属性有读权限)。
3、读多个特性值。客户端一次请求中读取几个句柄的特性值,服务器将这些特性值回应给客户端(假定属性有读权限)。客户端需要知道如何解析这些不同的特性值数据。
4、读特性描述符。客户端请求读特定句柄处的特性描述符,服务器将特性描述符的值回应给客户端设备(假定属性有读权限)。
5、使用UUID发现特性。客户端通过特性的类型(UUID)来请求发现这个特性的句柄。服务器将这个特性的声明回应给客户端设别,其中包括特性值的句柄以及特性的权限。
6、写特性值。客户端设备请求向服务器特定的句柄处写入特性值,服务器将数据是否写入成功的信息返回给客户端。
7、写特性描述符。客户端设备请求向服务器特定的句柄处写入特性描述符,服务器将特性描述符是否写入成功的信息反馈给客户端。
8、特性值通知。服务器将一个特性值通知给客户端。客户端设备不需要向服务器请求这个数据,当客户端收到这个数据时,也不需要回应服务器,但需要注意的是,要想使能服务器通知,首先要配置好特性,profile中定义了什么时候服务器应该发送这个数据。
每个profile初始化其相应的服务并内在地通过设备的GATT服务器来注册服务。GATT服务器将整个服务加到属性表中,并为每个属性分配唯一句柄。
GATT属性表中有一些特殊的属性类型,由SIG定义:
GATT_PRIMARY_SERVICE_UUID表示新服务的起始和提供的服务类型
GATT_CHARACTER_UUID 特性声明,紧随其后的是GATT特性值
GATT_CLIENT_CHAR_CFG_UUID 代表特性描述符,与属性表中它前面最精的句柄处的特性值相关,允许GATT客户端设备使能特性值通知
GATT_CHAR_DESC_UUIS 代表特性描述符,与属性表中它前面最精句柄处的特性值相关,包含一个ASCII字符串,是对相关的特性的描述。
总结:GATT包含若干个Profile,一个Profile包含若干个Services,一个Service包含若干个Characteristics,一个Characteristic包含Properties字段和若干个Descriptor(可选)。
GATT调用下层的ATT,ATT的attirbute在GATT中表现为Characteristic。
备注:转载自http://blog.csdn.net/zhaoshuzhaoshu/article/details/52354057
GATT两个角色 服务器与客户端的更多相关文章
- GATT 服务器与客户端角色
两个设备应用数据的通信是通过协议栈的GATT层实现的.从GATT角度来看,当两个设备建立连接后,他们处于以下两种角色之一: GATT服务器: 它是为GATT客户端提供数据服务的设备 GATT客户端: ...
- 看完这篇包你进大厂,实战即时聊天,一文说明白:聊天服务器+聊天客户端+Web管理控制台。
一.前言 说实话,写这个玩意儿是我上周刚刚产生的想法,本想写完后把代码挂上来赚点积分也不错.写完后发现这东西值得写一篇文章,授人予鱼不如授人以渔嘛(这句话是这么说的吧),顺便赚点应届学生MM的膜拜那就 ...
- 2016windows(10) wamp 最简单30分钟thrift入门使用讲解,实现php作为服务器和客户端的hello world
2016最简单windows(10) wamp 30分钟thrift入门使用讲解,实现php作为服务器和客户端的hello world thrift是什么 最简单解释 thrift是用来帮助各个编程语 ...
- python web编程-CGI帮助web服务器处理客户端编程
这几篇博客均来自python核心编程 如果你有任何疑问,欢迎联系我或者仔细查看这本书的地20章 另外推荐下这本书,希望对学习python的同学有所帮助 概念预热 eb客户端通过url请求web服务器里 ...
- golang thrift 源码分析,服务器和客户端究竟是如何工作的
首先编写thrift文件(rpcserver.thrift),运行thrift --gen go rpcserver.thrift,生成代码 namespace go rpc service RpcS ...
- homework-05 服务器与客户端
首先非常抱歉第三次和第四次作业我没交上来,不想找借口强调原因,但是这两次作业我一定会补上,到时候会@助教.谢谢 回到这次作业! 这次作业邹老师没说博客的格式,所以在这里就没有什么回答问题的东西了.这次 ...
- 单点登录CAS使用记(二):部署CAS服务器以及客户端
CAS-Server下载地址:https://www.apereo.org/projects/cas/download-cas CAS-Client下载地址:http://developer.jasi ...
- Linux系统编程(37)—— socket编程之UDP服务器与客户端
典型的UDP客户端/服务器通讯过程: 编写UDP Client程序的步骤 1.初始化sockaddr_in结构的变量,并赋值.这里使用"8888"作为连接的服务程序的端口,从命令行 ...
- [转]关于HTTP服务器每个客户端2个连接的限制
这两天猫在家里搞一个多线程的断点续传得C#程序,发现同时只能开2个线程下载,其他的线程一律要等待,这样就导致下载大文件时其他线程经常超时,郁闷好久.今天回公司无意中发现了一个帖子,终于真相大白了, 现 ...
随机推荐
- JavaScript入门篇 第三天(认识DOM)
认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...
- Openfire 的安装和配置
1. 下载最新的openfire安装文件 官方下载站点:http://www.igniterealtime.org/downloads/index.jsp#openfire 下载地址: Exe:htt ...
- 中介者模式(Mediator)
GOF:用一个中介对象来封装一系列的对象交互.中介者使对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 类图:
- Minimum no. of iterations to pass information to all nodes in the tree
Given a very large n-ary tree. Where the root node has some information which it wants to pass to al ...
- Apache Spark技术实战之6 -- spark-submit常见问题及其解决
除本人同意外,严禁一切转载,徽沪一郎. 概要 编写了独立运行的Spark Application之后,需要将其提交到Spark Cluster中运行,一般会采用spark-submit来进行应用的提交 ...
- java 求 两个数的百分比% (转)
int num1 = 7; int num2 = 9; // 创建一个数值格式化对象 NumberFormat numberFormat = NumberFormat.getInstance(); / ...
- 【爬虫】python之BeautifulSoup用法
1.爬虫 网络爬虫是捜索引擎抓取系统的重要组成部分.爬虫的主要目的是将互联网上的网页下载到本地形成一个或联网内容的镜像备份.通过分析和过滤HTML 代码,实现对图片.文字等资源的获取. 2.pytho ...
- Oracle SQL基本操作
Oracle数据库基本操作 1.概述 Oracle数据库客户端一般需要安装在服务器上,可以在服务器端操作,一般我们可以用sql developer工具远程连接到数据库,先行建立数据库,然后对表进行增删 ...
- ionic实现手机检测app是否安装,未安装则下载安装包,已安装则打开app(未实现iOS平台)
插件需求(上cordova官网下载): com.lampa.startapp cordova-plugin-appavailability cordova-plugin-inappbrowser 代码 ...
- Mac系统上用Node做APNS
1.安装Node,下载地址:http://nodejs.org 2.更新npm,终端命令:sudo npm update npm -g 3.安装apn,终端命令:npm install apn 4.导 ...