零基础入门学用物联网(ESP8266) 第一部分 基础知识篇(五)

参考教程:https://www.bilibili.com/video/BV1L7411c7jw/?spm_id_from=333.1387.favlist.content.click

九、ESP8266通过JSON实现物联网数据通讯

1、JSON基础

(1)JSON(JavaScript Object Notation)是一种通用的轻量级数据交换文本格式,它很容易让人阅读和编写,也便于机器进行解析和生成。它使用JavaScript语法来存储和描述数据对象,但是JSON完全独立于JavaScript,可适用于多种流行编程语言。

(2)JSON语法规则要点:

①JSON文件中,存在三个重要的概念------数据、对象和数组。

②数据以"数据名""数据值"对的方式呈现,"数据名"(也称键)和"数据值"(也称键值)之间由冒号分隔。

③大括号"{}"用于标注对象内容,中括号"[]"用于标注数组内容,逗号用于分隔数据、对象和数组。

(3)JSON数据:

①JSON数据的书写格式为""JSON数据名":JSON数据值",JSON数据名需要放在双引号中,比如"Year":2026、"URL":"www.example.com"。

②JSON数据值的类型可以是:数字(整数或浮点数)、字符串、逻辑值(true或false)、JSON数组(在中括号中)、JSON对象(在大括号中)、null。

③一个JSON数据名称只能对应一个值(这个值是广义上的值,比如数据名称对应一个数组,可认为它是对应一个广义上的值,这个值指的是这一个数组)。

(4)JSON对象:

①JSON对象是一个无序的JSON数据集合(也称键值对集合),也就是说,一个JSON对象可以包含单个或者多个JSON数据,但是需要注意的是,JSON对象不能直接存放JSON对象或JSON数组。

②一个JSON对象以"{"(左括号)开始,"}"(右括号)结束,每个"名称"后跟一个":"(冒号),键值对之间使用","(逗号)分隔。

③举例:如下所示,该JSON对象中包含两个JSON数据,数据名分别为"info"和"date",其中数据名"info"对应的数据值为一个包含两个JSON数据的JSON对象,数据名"date"对应的数据值为一个包含三个JSON数据的JSON对象。

javascript 复制代码
{
  "info": {
	"name": "taichi-maker",
	"website": "www.taichi-maker.com"
  },
  "date": {
	"year": 2020,
	"month": 12,
	"day": 30
  }
}

(5)JSON数组:

①JSON数组是相同元素的有序集合。

②一个JSON数组以"["(左中括号)开始,"]"(右中括号)结束,各元素之间使用","(逗号)分隔。

③JSON数组可包含一个或者多个JSON对象,如下所示。

javascript 复制代码
[
    {
      "name" : "taichi-maker",
      "website" : "www.taichi-maker.com"
   },
   {
      "year": 2020,
      "month": 12,
      "day": 30
   }
]

④数组也可以包含单个或多个数组,如下所示。

javascript 复制代码
[
    [
        {
            "name" : "taichi-maker",
            "website" : "www.taichi-maker.com"
        },
        {
            "year": 2020,
            "month": 12,
            "day": 30
        }
    ],
    [
        {
            "temperature" : 15,
        }
    ]		
]

⑤需要注意的是,JSON数组不能直接存放JSON数据,也就是说,所谓数组元素,不能是JSON数据。

(6)JSON对象与数组混合存放示例:

该JSON对象包含有一个JSON数据,数据名为results,该数据的值是一个JSON数组,此数组只含有一个JSON对象,此对象包含有三个JSON数据,这三个JSON数据的名称分别是------location、now和last_update,其中location的值是含有两个JSON数据的JSON对象,now的值是含有三个JSON数据的JSON对象,last_update的值是字符串"2020-03-01T20:10:00+08:00"

javascript 复制代码
{
  "results": [
    {
      "location": {
        "name": "Beijing",
        "country": "CN"
      },
      "now": {
        "text": "Clear",
        "code": "1",
        "temperature": "3"
      },
      "last_update": "2020-03-01T20:10:00+08:00"
    }
  ]
}
相关推荐
这波不该贪内存的7 小时前
裸机开发VS单片机:架构与实战对比
单片机
神一样的老师8 小时前
【兆易创新GD32VW553开发板试用】红外遥控接入天气时钟实战
驱动开发·单片机·嵌入式硬件
多看多敲多思考10 小时前
华润微CS32ME10 MCU使用教程(2)---CS32ME10之UART串口模块使用
stm32·单片机·嵌入式硬件·mcu
神一样的老师10 小时前
【兆易创新GD32VW553开发板试用】天气时钟设计与调试实战
单片机·嵌入式硬件·物联网
国科安芯11 小时前
核电站仪控与监测系统中抗辐射 MCU 芯片应用研究
单片机·嵌入式硬件·macos·无人机·cocos2d·核电站
黑白园11 小时前
STM32系统时钟由72M修改为36M验证示例
stm32·单片机·嵌入式硬件
左手厨刀右手茼蒿12 小时前
Linux 内核中的设备驱动开发:从字符设备到网络设备
linux·嵌入式·系统内核
LCG元12 小时前
基于ARM7的LCD设计与实现:S3C4510B通用IO口控制液晶模块
stm32·单片机·嵌入式硬件
The_superstar613 小时前
衡山派学习之串口
单片机·嵌入式硬件·串口·衡山派
Ww.xh13 小时前
STM32按键去抖动软件实现详解
stm32·单片机·嵌入式硬件