JSON

JavaScript Object Notation(JavaScript 对象表示法);

JSON是轻量级的文本数据交换格式;

JSON独立于语言,具有自我描述性,更易理解;

JSON语法规则

  • 数据由键(key)/值(value)描述,由逗号分隔
  • 大括号代表一个完整的对象,拥有多个键/值对
  • 中括号保存数组,多个对象之间使用逗号分隔
{
"site":[
{"name":"慕课网", "url":"www.imooc.com"},
{"name":"百度", "url":"www.baidu.com"},
{"name":"网易", "url":"www.163.com"}
]
}

JSON与字符串相互转换

  • JSON.parse()方法将字符串转换为JSON对象
  • JSON.stringify()方法将JSON对象转换为字符串
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
<!--JS中将字符串转换成JSON-->
var str = "{\"class_name\" : \"五年级一班\"}";
var json = JSON.parse(str);
console.log(str);
console.log(json);
document.write("班级:" + json.class_name + "<br>"); <!--JS中将JSON转换成字符串-->
var json2 = {"class_name" : "五年级二班"};
var str2 = JSON.stringify(json2);
console.info(json2);
console.info(str2);
document.write(str2 + "<br>"); <!--JS中JSON对象初始化-->
var json3 = {};
json3.class_name = "五年级三班";
console.log(json3);
document.write("班级:" + json3.class_name);
</script>
</head>
<body> </body>
</html>

JSON与Java交互

  • Java的JSON工具包还有FastJson、Jackson、Gson、Json-lib...
  • FastJson是阿里巴巴著名的JSON序列化与反序列工具包
  • FastJson国内拥有大量使用者,拥有API简单,效率高等优点

FastJSON对象序列化与反序列化

Employee.java

package demo;

import java.util.Date;

import com.alibaba.fastjson.annotation.JSONField;

public class Employee {
@JSONField(serialize = false) //serialize属性:不对该成员序列化
private int empId; private String empName; @JSONField(name = "hiredate", format = "yyyy-MM-dd") //JSON注解,name属性:说明key,format属性:将日期格式化
private Date empIn; public int getEmpId() {
return empId;
}
public void setEmpId(int empId) {
this.empId = empId;
}
public String getEmpName() {
return empName;
}
public void setEmpName(String empName) {
this.empName = empName;
}
public Date getEmpIn() {
return empIn;
}
public void setEmpIn(Date empIn) {
this.empIn = empIn;
} public Employee(int empId, String empName, Date empIn) {
super();
this.empId = empId;
this.empName = empName;
this.empIn = empIn;
} @Override
public String toString() {
return "Employee [empId=" + empId + ", empName=" + empName + ", empIn=" + empIn + "]";
} }

FastJsonSample.java

package demo;

import java.util.Calendar;

import com.alibaba.fastjson.JSON;

public class FastJsonSample {

	public static void main(String[] args) {
Calendar c = Calendar.getInstance();
c.set(2019, 1, 24);
Employee emp = new Employee(007, "星海", c.getTime());
String json = JSON.toJSONString(emp); //将Java对象转换成JSON字符串
System.out.println(json);
Employee emp2 = JSON.parseObject(json, Employee.class); //将JSON字符串转换成Java对象
System.out.println(emp2);
} }

控制台输出:

{"empName":"星海","hiredate":"2019-02-24"}
Employee [empId=0, empName=星海, empIn=Sun Feb 24 00:00:00 CST 2019]

FastJSON对象数组序列化与反序列化

  • JSON.toJSONString(list)将对象数组序列化
  • JSON.parseArray(json, Employee.class)将JSON数组反序列化

【JavaWeb】JSON基础的更多相关文章

  1. json基础

    1 xml缺点 用xml表示一个对象,数据存储效率低 <person> <firstName>Morra<firstName> <lastName>Do ...

  2. 【Java EE 学习 31】【JavaScript基础增强】【Ajax基础】【Json基础】

    一.JavaScript基础增强 1.弹窗 (1)使用window对象的showModelDialog方法和showModelessDialog方法分别可以弹出模式窗口和非模式窗口,但是只能在IE中使 ...

  3. JavaWeb:JavaBean基础

    JavaBean基础 JavaBean简介: 1.JavaBean是一种可以重复使用的类,可以没有用户界面,主要负责业务数据或者处理事物(数据运算.操作数据库) 2.与JSP配合,可以简化JSP代码. ...

  4. (转)JSON基础入门

    原文地址:http://kb.cnblogs.com/page/43982/ JSON 基础简单地说,JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松 ...

  5. JSON基础知识总结

    JSON基础 一.JSON简介 JSON,全称“JavaScript Object Notation(JavaScript对象表示法)”,起源于JavaScript的对象和数组.JSON,说白了就是J ...

  6. json基础教程|理解Json

    一. 在异步应用程序中发送和接收信息时,可以选择以纯文本和 XML 作为数据格式.这一期讨论一种有用的数据格式 JavaScript Object Notation(JSON),以及如何使用它更轻松地 ...

  7. json 基础

    json格式 JSON格式:http://www.json.org/ python和JSON的关系请参考:http://docs.python.org/library/json.html JSON建构 ...

  8. 最详细的JavaWeb开发基础之java环境搭建(Windows版)

    阅读文本大概需要 3 分钟. 首先欢迎大家来学习JavaWeb,在这里会给你比较详细的教程,从最基本的开始,循序渐进的深入.会让初学者的你少踩很多坑(大实话),如果你已经掌握了JavaWeb开发的基础 ...

  9. 关于JSON基础的总结

    本文总结自百度百科 JSON 语法规则 JSON 语法是 JavaScript 对象表示语法的子集. 数据在键值对中 数据由逗号分隔 花括号保存对象 方括号保存数组 JSON 名称/值对 JSON 数 ...

随机推荐

  1. CSS3动画的使用

    0921自我总结 CSS3动画的使用 一.动画的创建 @keyframes规则是创建动画 浏览器兼容 1.@keyframes myfirst 2.@-webkit-keyframes myfirst ...

  2. 松软科技带你学前端:JavaScript 输出

    JavaScript 不提供任何内建的打印或显示函数. JavaScript 显示方案 JavaScript 能够以不同方式“显示”数据: 使用 window.alert() 写入警告框 使用 doc ...

  3. https连接

        在发送连接之前设置显示握手过程:   System.setProperty("javax.net.debug", "all"); DubboServer ...

  4. Azure 架构师认证考试

    Azure认证路线 AZ-300 AZ-301 https://blog.csdn.net/pg_edb/article/details/86794505 免费题 https://iteablue.c ...

  5. 42-volume 生命周期管理

    Data Volume 中存放的是重要的应用数据,如何管理 volume 对应用至关重要.前面我们主要关注的是 volume 的创建.共享和使用,本节将讨论如何备份.恢复.迁移和销毁 volume. ...

  6. String类型中 "=="和"equals"比较的差别

    String类型中 "=="和"equals"比较的差别 先说明一下String类型的变量的创建方式 在创建新的String类型的变量时,首先会在缓冲区查找是否 ...

  7. Spring 事务 属性 详细

    学习东西要知行合一,如果只是知道理论而没实践过,那么掌握的也不会特别扎实,估计过几天就会忘记,接下来我们一起实践来学习Spring事务的传播属性. 传播属性 传播属性定义的是当一个事务方法碰到另一个事 ...

  8. git 现在本地创建仓库 再 推送到 远程 github 仓库中

    今天,需要再本地使用git管理代码,但是当代码创建好的时候,想发布到github上面的私有仓库中,但是没有提前创建远端仓库,所以需要把本地git仓库推送到远端另外一个仓库了,下面进行简要记录,刚刚经过 ...

  9. npm i xxxx -D和npm i xxxx-S的区别

    npm i xxxx -D 就是 npm i xxxx --save-dev 是把依赖写入进devDependencies对象里面 devDependencies 是开发环境下的依赖,这里是开发环境下 ...

  10. XOR加密作业

    思路 -1.对需要加密的内容进行MD5加密 -2.随机生产32位的十六进制密钥 -3.对密钥和MD5加密内容进行异或运算. 主要问题: -1.如何实现MD5加密 -2.如何随机生成32位16进制密钥 ...