Java后台如何接收与处理JSON类型数据
项目开发中偶尔会使用到某个为JSON类型的字段,一个字段中又包含多个其他的字段。
这种设计方式是根据实际需要来进行处理的,比如规则可能包含多条,每一条规则又包含
多个字段;再比如一些特殊的应用场景如标签是key-value形式的,可能有多个不同的标签。
这些场景下使用JSON或者是JSON数组来处理就会非常方便。具体该如何使用呢?
请看下面的示例代码:
@PostMapping("/json/test")
public JsonResult jsonParamTest(@Validated @RequestBody JsonParamTest jsonParamTest){
JsonResult jsonResult = new JsonResult();
// 校验
try {
JSON.parseObject(JSON.toJSONString(jsonParamTest.getJsonObject()));
} catch (Exception ex) {
log.error("json 对象参数错误--->{}", ex);
return jsonResult.declareFailure("50001","json对象参数错误", "");
}
try {
JSON.parseArray(JSON.toJSONString(jsonParamTest.getJsonArray()));
} catch (Exception ex) {
log.error("json 数组参数错误--->{}", ex);
return jsonResult.declareFailure("50002","json 数组参数错误", "");
}
try {
JSONArray jsonArray = JSON.parseArray(JSON.toJSONString(jsonParamTest.getJsonObjectArray()));
for(int i = 0, len = jsonArray.size(); i < len; i++) {
jsonArray.getJSONObject(i);
}
} catch (Exception ex) {
log.error("json 对象数组参数错误--->{}", ex);
return jsonResult.declareFailure("50003","json 对象数组参数错误", "");
}
jsonResult.declareSuccess("测试成功:");
return jsonResult;
}
@Data
public class JsonParamTest {
/*
* 名称
*/
@NotNull(message = "名称不能为null")
private String name;
/*
* json 对象类型
*/
@NotNull(message = "json 对象参数不能为null")
private Object jsonObject;
/*
* json 数组类型
*/
@NotNull(message = "json 数组参数不能为null")
private Object jsonArray;
/*
* json 对象数组类型
*/
@NotNull(message = "json 对象数组参数不能为null")
private Object jsonObjectArray;
}
说明:上面的示例代码是一个简单的请求输入类,和一个Controller中的常规方法。输入类中使用的
是hibernate中validator校验框架进行初步校验,主要测试三种JSON数据类型,一种是JSON对象,
一种是JSON数组,一种是JSON对象数组。控制器中的方法主要用于校验传递的参数是否正确,如果
错误则直接返回不在进行处理。代码中都是使用Object类型来接收JSON类型的数据,具体原因后面
会详细讲解。
下面是测试结果:
测试方式一:json对象参数错误的情况,符合预期:

测试方式二:json对象参数正确的情况,符合预期:

测试方式三:json 数组参数错误的情况,符合预期:

测试方式四:json 数组参数正确的情况,符合预期:

测试方式五:json 对象数组参数错误的情况,符合预期:

测试方式六:json 对象数组参数正确的情况,符合预期:

测试过程中遇到的问题如下:
.a.如果JSON类型的数据使用String类型来接收,比如将上面jsonObject字段类型修改为String类型,会报如下的错误,
org.springframework.http.converter.HttpMessageNotReadableException: Invalid JSON input: Cannot deserialize instance of `java.lang.String` out of START_OBJECT token; nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.lang.String` out of START_OBJECT token
.b.如果JSON数组类型的数据使用String类型来进行接收,比如将上面jsonArray字段类型修改为String类型,会报如下的错误,
org.springframework.http.converter.HttpMessageNotReadableException: Invalid JSON input: Cannot deserialize instance of `java.lang.String` out of START_ARRAY token; nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.lang.String` out of START_ARRAY token
解决方法,JSON类型的数据统一使用Java中的Object类型来进行接收。
.c.解析JSON数据时,如果是使用Java中的Object类型类接收数据,不能直接调用Object类型的toString()方法,
需要使用JSON.toJSONString()先进行处理。如下图所示:

注意事项:
.a.页面中传递JSON类型的数据时最好是使用Java中的Object类型类进行接收,解析的时候
使用JSON.toJSONString()转换一次即可,这样可以避免出现一些未知错误。如果从数据库中
查询的数据类型是JSON类型的,则不需要转换直接调用对象的toString()方法即可。
存储JSON类型的数据,Mysql可以考虑使用text字段;Postgresql数据库可以考虑使用jsonb类型
或者是json类型。
.b.如果不确定如何书写JSON类型的数据,则可以先打开谷歌浏览器,然后打开控制台,
进行简单的JOSN类型数据测试,JSON对象操作示例:

JSON数组操作示例:

.c.JSON对象、JSON数组、JSON对象数组的区别。
JSON对象:以一对{}符号包裹起来,全部是key-value形式的数据;
JSON数组:以一对[]符号包裹起来,数组形式的数据,数组里面的元素可以是JSON对象,也可以是字符串,或者是数组等等,没有限制;
JSON对象数组:以一对[]符号包裹起来,数组形式的数据,数组里面的元素只能是JSON对象。
Java后台如何接收与处理JSON类型数据的更多相关文章
- Struts2+Jquery实现ajax并返回json类型数据
来源于:http://my.oschina.net/simpleton/blog/139212 摘要 主要实现步骤如下: 1.JSP页面使用脚本代码执行ajax请求 2.Action中查询出需要返回的 ...
- 转载:Struts2+Jquery实现ajax并返回json类型数据
摘要: 主要实现步骤如下: 1.JSP页面使用脚本代码执行ajax请求 2.Action中查询出需要返回的数据,并转换为json类型模式数据 3.配置struts.xml文件 4.页面脚本接受并处理数 ...
- MySQL JSON 类型数据操作
1.Java 中动态扩展字段,会导致数据库表被锁,在MySQL 5.7.8版本之前,因为MySQL不能直接操作JSON类型数据,可以将一个字段设定成varchar类型,里面存放JSON格式数据,这样在 ...
- json进阶(一)js读取解析JSON类型数据
js读取解析JSON类型数据 一.什么是JSON? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式,同 ...
- js读取解析JSON类型数据【申明:来源于网络】
js读取解析JSON类型数据[申明:来源于网络] 地址:http://blog.csdn.net/sunhuaqiang1/article/details/47026841
- C#操作json类型数据
将对象序列化为 JavaScript 对象表示法 (JSON),并将 JSON 数据反序列化为对象. 此类不能继承. // msdn 例子: namespace SL_DataContractJson ...
- Python数据结构同Json类型数据相互转换的用法
在做Python接口自动化的时候,经常要用到Python数据结构同Json类型数据相互转换来供我们做进一步的验证提供数据,在此做个记录和总结 Python数据结构同Json类型数据相互转换的函数有:j ...
- ajax接收遍历处理json格式数据
ajax在前后端的交互中应用非常广泛,通过请求后台接口接收处理json格式数据展现在前端页面. 下面我们来简单用 ajax在本地做一个接收并处理json的小例子 首先我们要新建一个叫做data的jso ...
- 用springmvc的@RequestBody和@ResponseBody 接收和响应json格式数据
1.controller @Controller @RequestMapping("/rest/v1") public class WelcomeController { @Req ...
- mysql 5.7 laravel json类型数据相关操作
2018年10月16日18:14:21 官方文档中文翻译版 原文:https://dev.mysql.com/doc/refman/5.7/en/json.html 最后有部分实例和一个小总结 11. ...
随机推荐
- 基于JESD204B和PCIe DMA的多通道数据采集和回放系统
基于JESD204B和PCIe DMA的多通道数据采集和回放系统 在主机端PCIe驱动的控制和调度下,数据采集与回放系统可以同时完成对多个JESD204B接口AD数据的采集以及JESD204B接口DA ...
- ES6 学习笔记(二)解构赋值
一.数组的解构赋值 1.基本用法 ES6允许按照一定模式从数组和对象中提取值,然后对变量进行赋值,该操作即为解构 如: let [a,b,c]=[1,2,3]; console.log(a,b,c) ...
- .NET应用开发之SQLServer常见问题分析
日常我们开发.NET应用时会使用SQLServer数据库,对于SQLServer数据库的日常开发有一些技能和工具,准备给大家分享一下. 一.场景1:SQLServer死锁分析 执行以下SQL,启用S ...
- 解决头部使用 position:fixed; 固定定位后遮住下方内容的问题
1.在头部下面给一个空的 div 给这个div设置高度,把页面撑开,这种方法是让头部刚好遮住的是这个空div,把内容放出来. 但是这种方法需要一点点调试高度,所以不推荐. 2.把整个要使用 posit ...
- 查看、校验、归档…带你掌握openGauss账本数据库
摘要:账本数据库融合了区块链思想,将用户操作记录至两种历史表中:用户历史表和全局区块表. 本文分享自华为云社区<openGauss账本数据库,你不知道的那些事儿>,作者:Gauss松鼠会 ...
- fastjson远程代码执行漏洞
fastjson漏洞学习记录 免责声明: Fastjson 1.2.24 远程代码执行漏洞 漏洞说明 前提条件 影响范围 漏洞复现 Fastjson<=1.2.47 远程代码执行漏洞 Fastj ...
- 工作总结:kafka踩过的坑
餐饮系统每天中午和晚上用餐高峰期,系统的并发量不容小觑.公司规定各部门都要轮流值班,防止出现线上问题时能够及时处理. 后厨显示系统属于订单的下游业务. 用户点完菜下单后,订单系统会通过发 Kafka ...
- Linux Framebuffer 实验
一.准备 linux虚拟机或ARM开发板 Ubuntu18.04 二.Framebuffer介绍 次笔记主要的目的是实验,所以我不介绍了,有需要的小伙伴可以去看下面博客 Linux LCD Framb ...
- Kubernetes_从零开始搭建k8s集群(亲测可用)
一.前言 本文讲述从零开始搭建k8s集群,均使用国内镜像,版本均统一,使用两个虚拟机,一个主节点,一个从节点,保证k8s一次搭建成功. 注意:Kubernetes,简称K8s,是用8代替名字中间的8个 ...
- 流程编排、如此简单-通用流程编排组件JDEasyFlow介绍
作者:李玉亮 JDEasyFlow是企业金融研发部自研的通用流程编排技术组件,适用于服务编排.工作流.审批流等场景,该组件已开源(https://github.com/JDEasyFlow/jd-ea ...