To Noob Json是什么鬼?

To Noob Json是什么鬼?

大家好,又见面了,我是全栈君。

转载请注明出处王亟亟的大牛之路
供应商A:那我们数据怎么交互啊?HTTP吧?那内容呢?JSON?XML?
小菜鸟B:JSON什么鬼?
为了菜鸟们避免以上情况楼主写一发JSON的博文,废话不多!開始!

先梳理下概念
1.JSON是什么
JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)
JSON 是轻量级的文本数据交换格式
JSON 独立于语言 *
JSON 具有自我描写叙述性,更易理解
JSON 使用 Javascript语法来描写叙述数据对象,可是 JSON 仍然独立于语言和平台。

JSON 解析器和 JSON 库支持很多不同的编程语言。

眼下非常多的动态(PHP,JSP。.NET)编程语言都支持JSON。

2.JSON和XML的同样点以及不同点
同样:
JSON 是纯文本
JSON 具有”自我描写叙述性”(人类可读)
JSON 具有层级结构(值中存在值)
JSON 可通过 JavaScript 进行解析
JSON 数据可使用 AJAX 进行传输
不同:
没有结束标签
更短
读写的速度更快
可以使用内建的 JavaScript eval() 方法进行解析
使用数组
不使用保留字

样例:
简单的JSON对象

{
    "name": "wjj"
}
简单的样例。这是一个叫name的json对象,属性是字符串wjj。
{
    "action": 123
}
我们办了变,他如今有一个属性。只是是int型的。值是123.

在我们人工读的时候,非常轻易就能解读那一段json字符串

JSON的数据类型
JSON 值可以是:

数字(整数或浮点数)
字符串(在双引號中)
逻辑值(true 或 false)
数组(在方括号里)
对象(在花括号里)
null

实例
要被解析的json字符串

{
    "phone": [ "1000000", "2000000" ],
    "name": "wjj",
    "age": 20,
    "address": { "country": "china", "province": "shanghai" },
    "married": false }

上面这段json字符串简单的说明了一个人的一些属性,各种类型的数据一目了然,那我们来试着写写这段JSON.

try {  
    // 首先最外层是{},是创建一个对象 
    JSONObject person = new JSONObject();  
    // 第一个键phone的值是数组。所以须要创建数组对象 
    JSONArray phone = new JSONArray();  
    phone.put("1000000").put("2000000");  
    person.put("phone", phone);  

    person.put("name", "wjj");  
    person.put("age", 20);  
    // 键address的值是对象,所以又要创建一个对象 
    JSONObject address = new JSONObject();  
    address.put("country", "china");  
    address.put("province", "shanghai");  
    person.put("address", address);    
    person.put("married", false);  
} catch (JSONException ex) {  
    // 键为null或使用json不支持的数字格式(NaN, infinities) 
    throw new RuntimeException(ex);  
}  

然后 再试着拆这段JSON

try {

    JSONObject jsonObject = new JSONObject(jsonData);
    person.phoneArray=jsonObject.optJSONArray("phone ");
    person.name=jsonObject.optString("name");
    person.age=jsonObject.optInt("age");
    JSONArray jsonObject1=jsonObject.opJSONArray("address");
    person.country=jsonObject1.opString("country");
    person.province=jsonObject1.opString("province");
    person.married=jsonObject.opBoolean("married"); 
     } catch (JSONException e) {
            e.printStackTrace();
        }

就是如此。一层一层拨开,逻辑非常清晰哦。

再推荐一些方便平时读JSON的地址 :
http://www.bejson.com/
http://json.cn/

今天就到这里。谢谢大家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115465.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mysql 全文索引 使用_MySql全文索引

    mysql 全文索引 使用_MySql全文索引使用索引是数据库性能优化的必备技能之一。在MySQL数据库中,有四种索引:聚集索引(主键索引)、普通索引、唯一索引以及我们这里将要介绍的全文索引(FULLTEXTINDEX)。全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它能够利用「分词技术「等多种算法智能分析出文本文字中关键字词的频率及重要性,然后按照一定的算法规则智能地筛选出我们想要的搜索结果。在这里,我们就不追根究底其底层实现…

    2022年6月21日
    31
  • 一款强大的网站在线客服聊天系统:whisper搭建教程

    一款强大的网站在线客服聊天系统:whisper搭建教程简介whisper是一个在线客服系统源码,采用thinkphp5+Gatewayworker编写,性能强悍。自己搭建,控制在自己,也无需为您的数据安全担心,您可以应用在任何的正规的网站,只需要添加一段简单的js代码,就可以使您的网站拥有在线客服功能。官方网站:http://whisper.baiyf.com/截图功能支持客服分组,多客服服务,让您的服务更有条理。 支持客服…

    2022年7月19日
    28
  • Python#Typora-Python笔记[通俗易懂]

    Python#Typora-Python笔记[通俗易懂]python基础笔记

    2022年5月12日
    32
  • 机器学习 — 多项式回归

    机器学习 — 多项式回归前言在面对一些简单的线性问题时。线性回归能够用一个直线较为精确地描述数据之间的关系。但对于复杂的非线性数据问题时。线性回归的效果就大大不如意了。对特征数据进行多项式变化,再使用线性回归的做法就能提高模型的拟合效果,这种方法就是多项式回归。从面对上图1中的数据,线性回归不能准确描述数据关系。无论一次方、二次方、三次方、四次方都不能单独完美拟合数据。在多项式中集成了一次方、二次方、三次方、四次方…

    2025年6月17日
    1
  • webpack-ES6转ES5[通俗易懂]

    webpack-ES6转ES5[通俗易懂]@webpack-ES6转ES5的babel-loader安装babel-loader:npminstall–savedevbabel-loader@7babel-corebabel-preset-es2015用法:在webpack配置对象中,需要将babel-loader添加到module列表中module:{rules:[{test:/\.m?js$/,exclude:/(node_modules|bower_c

    2022年9月17日
    0
  • print()方法和println()方法的区别_println的用法

    print()方法和println()方法的区别_println的用法今天在写一个关于socket的程序,无意间把PrintWriter中的print与println混淆了,于是写了个小demo测试了一下,代码如下:服务端代码:packagecom.city.server;importjava.io.BufferedReader;importjava.io.InputStreamReader;importjava.io.PrintWriter;…

    2022年8月10日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号