JavaWeb 之 JSON

Wesley13
• 阅读 763

一、概述

  1、概念

JSON:JavaScript Object Notation  JavaScript对象表示法

  2、基本格式

var p = {"name":"张三","age":23,"sex":"男"};

  3、用途和优点

(1)json 现在多用于存储和交换文本信息的语法

(2)进行数据的传输

(3)JSON 比 XML 更小、更快,更易解析

二、语法

  1、基本规则

(1)数据在名称/值对中:json 数据是由键值对构成的。

① 键用引号(单双都行)引起来,也可以不使用引号

② 值的类型:

a、数字(整数或浮点数)

b、字符串(在双引号中)

c、逻辑值(true 或 false)

d、数组(在方括号中) 如:{"persons":[{},{}]}

e、对象(在花括号中) 如: {"address":{"province":"河北"....}}

f、null :控制

(2)数据有逗号分隔:多个键值对由逗号分隔

(3)花括号保存对象:使用 {} 定义 json 格式

(4)方括号保存数据:[]

  2、获取数据

(1)json对象.键名

(2)json对象["键名"]

(3)数组对象[索引]

(4)遍历对象

代码演示:

 1   <script>
 2         //1.定义基本格式
 3         var person = {"name": "张三", age: 23, 'sex': true};
 4 
 5         var ps = [{"name": "张三", "age": 23, "sex": true},
 6             {"name": "李四", "age": 24, "sex": true},
 7             {"name": "王五", "age": 25, "sex": false}];
 8 
 9 
10 
11 
12         //获取person对象中所有的键和值
13         //for in 循环
14        /* for(var key in person){
15             //这样的方式获取不行,key 是字符串类型。因为相当于  person."name"
16             //alert(key + ":" + person.key);
17             alert(key+":"+person[key]);
18         }*/
19 
20        //获取ps中的所有值
21         for (var i = 0; i < ps.length; i++) {
22             var p = ps[i];
23             for(var key in p){
24                 alert(key+":"+p[key]);
25             }
26         }
27 
28     </script>

三、JSON 数据和 Java 对象的相互转换

  1、JSON 解析器

常见的解析器:Jsonlib,Gson,fastjson,jackson

  2、Java 对象转换为 JSON

使用步骤:

(1)导入 Jackson 的相关 jar 包

(2)创建 Jackson 的核心对象 ObjectMapper

(3)调用 ObjectMapper 的相关方法进行转换

转换方法

writeValue(参数1,obj):

   参数1:

            • File:将obj对象转换为JSON字符串,并保存到指定的文件中
            • Writer:将obj对象转换为JSON字符串,并将json数据填充到字符输出流中
            • OutputStream:将obj对象转换为JSON字符串,并将json数据填充到字节输出流中

    writeValueAsString(obj):将对象转为json字符串

注解

 @JsonIgnore:排除属性。   // 加到 JavaBean 上时,便不会对该属性转化为 json 数据
 @JsonFormat:属性值得格式化 // 多用于时间类型的成员变量上,来格式化,如@JsonFormat(pattern = "yyyy-MM-dd")

复杂 java 对象转换

对于 List 和 Map 集合来说,转换成 json 数据后,会转换为一个对象数组字符串。

  3、JSON 对象转为 Java 对象

步骤同上,只是调用的方法不同。

转化为 Java 对象的方法:

readValue(json字符串数据,转化为类型的Class)

      代码演示:

 1 public void test() throws Exception {
 2        //1.初始化JSON字符串
 3         String json = "{\"sex\":\"男\",\"name\":\"张三\",\"age\":23}";
 4 
 5         //2.创建ObjectMapper对象
 6         ObjectMapper mapper = new ObjectMapper();
 7         //3.转换为Java对象 Person对象
 8         Person person = mapper.readValue(json, Person.class);
 9 
10         System.out.println(person);
11     }

四、检验用户是否存在案例

需求:

1、在注册页面进行验证,当用户输入用户名时,如果已经存在该用户名,提示“此用户名太受欢迎,请更换一个”;

2、如果没有用户名存在,提示"用户名可用"

代码实现:

注册页面:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>注册页面</title>
 6     <script src="js/jquery-3.3.1.min.js"></script>
 7 
 8 
 9     <script>
10         //在页面加载完成后
11         $(function () {
12            //给username绑定blur事件
13            $("#username").blur(function () {
14                //获取username文本输入框的值
15                var username = $(this).val();
16                //发送ajax请求
17                //期望服务器响应回的数据格式:{"userExsit":true,"msg":"此用户名太受欢迎,请更换一个"}
18                //                         {"userExsit":false,"msg":"用户名可用"}
19                $.get("findUserServlet",{username:username},function (data) {
20                    //判断userExsit键的值是否是true
21 
22                    // alert(data);
23                    var span = $("#s_username");
24                    if(data.userExsit){
25                        //用户名存在
26                        span.css("color","red");
27                        span.html(data.msg);
28                    }else{
29                        //用户名不存在
30                        span.css("color","green");
31                        span.html(data.msg);
32                    }
33                },"json");   // 设置返回数据为json
34 
35            }); 
36         });
37 
38     </script>
39 </head>
40 <body>
41 
42 
43     <form>
44 
45         <input type="text" id="username" name="username" placeholder="请输入用户名">
46         <span id="s_username"></span>
47         <br>
48         <input type="password" name="password" placeholder="请输入密码"><br>
49         <input type="submit" value="注册"><br>
50 
51     </form>
52 
53 </body>
54 </html>

服务器端代码:

 1 import com.fasterxml.jackson.databind.ObjectMapper;
 2 import javax.servlet.ServletException;
 3 import javax.servlet.annotation.WebServlet;
 4 import javax.servlet.http.HttpServlet;
 5 import javax.servlet.http.HttpServletRequest;
 6 import javax.servlet.http.HttpServletResponse;
 7 import java.io.IOException;
 8 import java.util.HashMap;
 9 import java.util.Map;
10 
11 @WebServlet("/findUserServlet")
12 public class FindUserServlet extends HttpServlet {
13     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
14         //1.获取用户名
15         String username = request.getParameter("username");
16 
17         //2.调用service层判断用户名是否存在
18 
19         //期望服务器响应回的数据格式:{"userExsit":true,"msg":"此用户名太受欢迎,请更换一个"}
20         //                         {"userExsit":false,"msg":"用户名可用"}
21 
22         //设置响应的数据格式为json
23         response.setContentType("application/json;charset=utf-8");
24         Map<String,Object> map = new HashMap<String,Object>();
25 
26         if("jack".equals(username)){
27             //存在
28             map.put("userExsit",true);
29             map.put("msg","此用户名太受欢迎,请更换一个");
30         }else{
31             //不存在
32             map.put("userExsit",false);
33             map.put("msg","用户名可用");
34         }
35 
36         //将map转为json,并且传递给客户端
37         //将map转为json
38         ObjectMapper mapper = new ObjectMapper();
39         //并且传递给客户端
40         mapper.writeValue(response.getWriter(),map);
41 
42 
43     }
44 
45     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
46         this.doPost(request, response);
47     }
48 }
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
List的Select 和Select().tolist()
List<PersondelpnewList<Person{newPerson{Id1,Name"小明1",Age11,Sign0},newPerson{Id2,Name"小明2",Age12,
Wesley13 Wesley13
3年前
JSON笔记
一、1、  JSON.stringify(obj)将JSON转为字符串:      vara{"name":"tom","sex":"男","age":"24"};      varaToStrJSON.stringify(a);      alert(aToStr);//结果:{"na
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
3年前
Gson之实例五
前面四篇博客基本上可以满足我们处理的绝大多数需求,但有时项目中对json有特殊的格式规定.比如下面的json串解析:{"tableName":"students","tableData":{"id":1,"name":"李坤","birthDay":"Jun 22, 2012 9:54:49 PM"},{"id":2,"name":"曹贵生"
Wesley13 Wesley13
3年前
JSON教程
JSON教程JSON:JavaScript对象表示法(JavaScriptObjectNotation)。JSON是存储和交换文本信息的语法。类似XML。JSON比XML更小、更快,更易解析。每一章中用到的实例{    "star_male":    {