前端传参对象套对象的格式,后端进行解析并存入数据库
项目场景:
在一些小程序中会涉及到一个表单中的一个数组对象中夹杂着另一个对象数据,这个被夹杂的数据是from表单内的一组单选或者双选这样的数据,前端转为json对象之后传到后端进行解析
问题描述
首先传进来的对象是这样的格式的
abc:{"a":"0","a":"1","a":"0","a":"0","a":"1","a":"0",abcd={"a":"0","a":"0","a":"0","a":"0"},"a":"0"}
他是对象套对象的格式,有两个需求第一个是内部里面的这个对象需要取出来根据指定名称进行拼接存入一个字段然后和整个对象一起存入到第一个a表内,然后遍历第二个对象根据名称进行业务处理之后依次存入第二个b表内
解决方案:
我采取的时迭代器和for循环实现的,迭代器晒出内部对象,然后放入map内,for循环遍历map进行业务处理,下面是具体的实现步骤
这是简化代码,下面是我具体的业务处理,用的都是比较常见的方法
JSONObject jsonInfo = new JSONObject();
jsonInfo.put("add", houseSafetyContents);Map<String, Map<String, String>> map = new TreeMap<>(); // 使用TreeMap来存储键值对,保证按照键的自然顺序遍历
Iterator<String> keys = jsonInfo.keys();
while (keys.hasNext()) {
String key = keys.next();
JSONObject value = jsonInfo.getJSONObject(key);
Map<String, String> innerMap = new HashMap<>();
Iterator<String> innerKeys = value.keys();
while (innerKeys.hasNext()) {
String innerKey = innerKeys.next();
String innerValue = value.getString(innerKey);
System.out.println(innerValue);
System.out.println(innerKey);
innerMap.put(innerKey, innerValue);
}
map.put(key, innerMap);
}// 按照键的自然顺序遍历键值对
for (Map.Entry<String, Map<String, String>> entry : map.entrySet()) {
String key = entry.getKey();
Map<String, String> innerMap = entry.getValue();
System.out.println("Key: " + key);
for (Map.Entry<String, String> innerEntry : innerMap.entrySet()) {
String innerKey = innerEntry.getKey();
String innerValue = innerEntry.getValue();
System.out.println(innerKey + " - " + innerValue);
}
}
public List<QdmHousesaFetyVO> insertSecurityCheck(QdmHousesaFetyVO qdmHousesaFetyVO) {QdmHousesaFetyinfoVO qdmHousesaFetyinfoVO = new QdmHousesaFetyinfoVO();//定义拼接安检内容的字段String contents = null;String contents1 = null;String contents8 = null;String contents9 = null;String contents10 = null;String contents11 = null;String contents13 = null;String contents14 = null;String contents15 = null;String contents16 = null;String contents17 = null;String contents18 = null;JSONObject jsonInfo = new JSONObject();//将安检内容转为字符串String jsonString = qdmHousesaFetyVO.getHouseSafetyContents().toString();//将抓换字符串的安检内容转为jsonJSONObject houseSafetyContents = new JSONObject(jsonString);//传入到json对象准备遍历jsonInfo.put("add", houseSafetyContents);Map<String, Map<String, String>> map = new TreeMap<>(); // 使用TreeMap来存储键值对,保证按照键的自然顺序遍历 存放存入安检表的mapMap<String, Map<String, String>> map1 = new TreeMap<>(); // 使用TreeMap来存储键值对,保证按照键的自然顺序遍历 存放全部安检的map//获取里面的keyIterator<String> keys = jsonInfo.keys();//定义迭代器 遍历这个json对象 获取key并赋值,然后通过这个赋值的key得到对应值while (keys.hasNext()) {String key = keys.next();JSONObject value = jsonInfo.getJSONObject(key);Map<String, String> innerMap = new HashMap<>();Iterator<String> innerKeys = value.keys();//定义第二个迭代器 遍历这个内层的value里面的key和value,然后将key对应的value赋值while (innerKeys.hasNext()) {String innerKey = innerKeys.next();String innerValue = value.getString(innerKey);innerMap.put(innerKey, innerValue);}map.put(key, innerMap);map1.put(key, innerMap);} // 打印结果//第一个循环 获取外层的map 得到内层的数据在存入到mapfor (Map.Entry<String, Map<String, String>> entry : map1.entrySet()) {String key = entry.getKey();Map<String, String> innerMap = entry.getValue();//第二个循环 遍历内部的map 获得想要的数据for (Map.Entry<String, String> innerEntry : innerMap.entrySet()) {String innerKey = innerEntry.getKey();String innerValue = innerEntry.getValue();if (innerKey.equals("fuel_1")) {qdmHousesaFetyinfoVO.setContents("是否在开放式厨房使用燃气");if (innerValue.equals("1")) {//1是合格0不为合格qdmHousesaFetyinfoVO.setIsConformity("是");}if (innerValue.equals("0")) {qdmHousesaFetyinfoVO.setIsConformity("否");}contents = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}if (innerKey.equals("fuel_2")) {qdmHousesaFetyinfoVO.setContents("是否存在双气源、双火源");if (innerValue.equals("1")) {//1是合格0不为合格qdmHousesaFetyinfoVO.setIsConformity("是");}if (innerValue.equals("0")) {//1是不合格0为合格qdmHousesaFetyinfoVO.setIsConformity("否");}contents1 = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}if (innerKey.equals("siren_1")) {qdmHousesaFetyinfoVO.setContents("是否具备燃气安全技防装置(报警器与切断连锁装置或自闭阀)");if (innerValue.equals("1")) {//1是合格0不为合格qdmHousesaFetyinfoVO.setIsConformity("是");}if (innerValue.equals("0")) {//1是不合格0为合格qdmHousesaFetyinfoVO.setIsConformity("否");}contents8 = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}if (innerKey.equals("siren_2")) {System.out.println("");qdmHousesaFetyinfoVO.setContents("报警器是否在工作状态");if (innerValue.equals("1")) {//1是合格0不为合格qdmHousesaFetyinfoVO.setIsConformity("是");}if (innerValue.equals("0")) {//1是不合格0为合格qdmHousesaFetyinfoVO.setIsConformity("否");}contents9 = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}if (innerKey.equals("link_1")) {System.out.println("");qdmHousesaFetyinfoVO.setContents("是否使用金属波纹连接管");if (innerValue.equals("1")) {//1是合格0不为合格qdmHousesaFetyinfoVO.setIsConformity("是");}if (innerValue.equals("0")) {//1是不合格0为合格qdmHousesaFetyinfoVO.setIsConformity("否");}contents13 = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}if (innerKey.equals("link_2")) {System.out.println("");qdmHousesaFetyinfoVO.setContents("连接管是否超长(大于2m)");if (innerValue.equals("1")) {//1是合格0不为合格qdmHousesaFetyinfoVO.setIsConformity("是");}if (innerValue.equals("0")) {//1是不合格0为合格qdmHousesaFetyinfoVO.setIsConformity("否");}contents14 = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}contents18 = qdmHousesaFetyinfoVO.getContents() + "" + qdmHousesaFetyinfoVO.getIsConformity();}// System.out.println(innerKey + " - " + innerValue);}}qdmHousesaFetyVO.setHouseSafetyContents(contents+";"+contents1+";"+contents8+";"+contents9+";"+contents10+";"+contents11+";"+contents13+";"+contents14+";"+contents15+";"+contents16+";"+contents17+";"+contents18);qdmSecCheMapper.insertCustomerDetails(qdmHousesaFetyVO);int ID = qdmSecCheMapper.selectID(); // System.out.println("selectID: "+ID);for (Map.Entry<String, Map<String, String>> entry : map.entrySet()) {String key = entry.getKey();Map<String, String> innerMap = entry.getValue(); // System.out.println("Key: " + key);for (Map.Entry<String, String> innerEntry : innerMap.entrySet()) {String innerKey = innerEntry.getKey();String innerValue = innerEntry.getValue();switch(innerKey) {case "fuel_1" : qdmHousesaFetyinfoVO.setModule("燃气使用环境");qdmHousesaFetyinfoVO.setContents("是否在开放式厨房使用燃气");if (innerValue.equals("1")){//1是不合格0为合格qdmHousesaFetyinfoVO.setCheckResult("是");qdmHousesaFetyinfoVO.setIsConformity("合格");qdmHousesaFetyinfoVO.setIsConformityInt("1");}if (innerValue.equals("0")){//1是不合格0为合格qdmHousesaFetyinfoVO.setCheckResult("否");qdmHousesaFetyinfoVO.setIsConformity("不合格");qdmHousesaFetyinfoVO.setIsConformityInt("0");}qdmHousesaFetyinfoVO.setInfoID(ID);qdmSecCheMapper.inserthousesafetyinfo(qdmHousesaFetyinfoVO);break;case "fuel_2" : qdmHousesaFetyinfoVO.setModule("燃气使用环境");qdmHousesaFetyinfoVO.setContents("是否存在双气源、双火源");if (innerValue.equals("1")){//1是不合格0为合格qdmHousesaFetyinfoVO.setCheckResult("是");qdmHousesaFetyinfoVO.setIsConformity("合格");qdmHousesaFetyinfoVO.setIsConformityInt("1");}if (innerValue.equals("0")){//1是不合格0为合格qdmHousesaFetyinfoVO.setCheckResult("否");qdmHousesaFetyinfoVO.setIsConformity("不合格");qdmHousesaFetyinfoVO.setIsConformityInt("0");}qdmHousesaFetyinfoVO.setInfoID(ID);qdmSecCheMapper.inserthousesafetyinfo(qdmHousesaFetyinfoVO);break;case "siren_1" :qdmHousesaFetyinfoVO.setModule("报警器及与其联动的切断装置");qdmHousesaFetyinfoVO.setContents("是否具备燃气安全技防装置(报警器与切断连锁装置或自闭阀)");if (innerValue.equals("1")){//1是合格0为不合格qdmHousesaFetyinfoVO.setCheckResult("是");qdmHousesaFetyinfoVO.setIsConformity("合格");qdmHousesaFetyinfoVO.setIsConformityInt("1");}if (innerValue.equals("0")){//1是合格0为不合格qdmHousesaFetyinfoVO.setCheckResult("否");qdmHousesaFetyinfoVO.setIsConformity("不合格");qdmHousesaFetyinfoVO.setIsConformityInt("0");}qdmHousesaFetyinfoVO.setInfoID(ID);qdmSecCheMapper.inserthousesafetyinfo(qdmHousesaFetyinfoVO);break;case "siren_2" : qdmHousesaFetyinfoVO.setModule("报警器及与其联动的切断装置");qdmHousesaFetyinfoVO.setContents("报警器是否在工作状态");if (innerValue.equals("1")){//1是合格0为不合格qdmHousesaFetyinfoVO.setCheckResult("是");qdmHousesaFetyinfoVO.setIsConformity("合格");qdmHousesaFetyinfoVO.setIsConformityInt("1");}if (innerValue.equals("0")){//1是合格0为不合格qdmHousesaFetyinfoVO.setCheckResult("否");qdmHousesaFetyinfoVO.setIsConformity("不合格");qdmHousesaFetyinfoVO.setIsConformityInt("0");}qdmHousesaFetyinfoVO.setInfoID(ID);qdmSecCheMapper.inserthousesafetyinfo(qdmHousesaFetyinfoVO);break;case "link_1" : qdmHousesaFetyinfoVO.setModule("连接软管与灶具");qdmHousesaFetyinfoVO.setContents("是否使用金属波纹连接管");if (innerValue.equals("1")){//1是合格0为不合格qdmHousesaFetyinfoVO.setCheckResult("是");qdmHousesaFetyinfoVO.setIsConformity("合格");qdmHousesaFetyinfoVO.setIsConformityInt("1");}if (innerValue.equals("0")){//1是合格0为不合格qdmHousesaFetyinfoVO.setCheckResult("否");qdmHousesaFetyinfoVO.setIsConformity("不合格");qdmHousesaFetyinfoVO.setIsConformityInt("0");}qdmHousesaFetyinfoVO.setInfoID(ID);qdmSecCheMapper.inserthousesafetyinfo(qdmHousesaFetyinfoVO);break;case "link_2" : qdmHousesaFetyinfoVO.setModule("连接软管与灶具");qdmHousesaFetyinfoVO.setContents("连接管是否超长(大于2m)");if (innerValue.equals("1")){//0是合格1为不合格qdmHousesaFetyinfoVO.setCheckResult("是");qdmHousesaFetyinfoVO.setIsConformity("合格");qdmHousesaFetyinfoVO.setIsConformityInt("1");}if (innerValue.equals("0")){//0是合格1为不合格qdmHousesaFetyinfoVO.setCheckResult("否");qdmHousesaFetyinfoVO.setIsConformity("不合格");qdmHousesaFetyinfoVO.setIsConformityInt("0");}qdmHousesaFetyinfoVO.setInfoID(ID);qdmSecCheMapper.inserthousesafetyinfo(qdmHousesaFetyinfoVO);break;default : System.out.println(0);}}}List<QdmHousesaFetyinfoVO> Housesa = qdmSecCheMapper.selectHousesa(ID);String qualified = "1";for (int i = 0; i < Housesa.size(); i++) {QdmHousesaFetyinfoVO house = Housesa.get(i);String IsConformityInt = house.getIsConformityInt();String IsConformity = house.getIsConformity();if (IsConformityInt.equals("0") || IsConformity.equals("不合格")) {qualified = "0";break;}}qdmSecCheMapper.updateYhqhousesafety(ID, qualified);List<QdmHousesaFetyVO> data = qdmSecCheMapper.selecthousesafetyinfo();System.out.println(data);return data;}
相关文章:

前端传参对象套对象的格式,后端进行解析并存入数据库
项目场景: 在一些小程序中会涉及到一个表单中的一个数组对象中夹杂着另一个对象数据,这个被夹杂的数据是from表单内的一组单选或者双选这样的数据,前端转为json对象之后传到后端进行解析 问题描述 首先传进来的对象是这样的格式的 abc:{"a":"0&quo…...

WordPress 网站使用 CDN 后获取访客真实 IP
WordPress 往数据库存 IP 的时候似乎用的是 REMOTE_ADDR,这样一来数据库里面的评论信息就全是从各个 CDN 服务器来的 IP。 在 wp-config.php 文件中增加下面代码就可以获取 CDN 后访客的真实 IP。这个函数的核心是用解析后的 HTTP_X_FORWARDED_FOR 替换 REMOTE_ADD…...

mysql my.ini、登录、用户相关操作、密码管理、权限管理、权限表,角色管理
my.ini 配置文件格式 登录mysql mysql -h hostname | IP -P port -u username -p database -e “select 语句”; 创建用户、修改用户、删除用户 create user ‘zen’ identified by ‘密码’ ## host 默认是 % create user ‘zen’‘localhost’ identified by ‘密…...

UUID和数据库主键
UUID uuid是由网卡MAC地址、时间戳、名字空间(Namespace)、随机或伪随机数、时序等因素随机生成的一个字符串。有128位,重合概率是2的128次方。 Unique 突发奇想用uuid做数据库主键。 可以保证全局唯一性可以分布式生成无序插入可以避免锁…...

uniapp:蓝牙模块
模拟的是蓝牙设备签到/签出: 获取指定蓝牙设备蓝牙初始搜索次数限制,超过限制就停止搜索蓝牙连接失败次数限制,超过限制标识蓝牙连接失败(离开蓝牙范围或其他原因)自动重连指定蓝牙 const device ref<any>(nu…...

探索链表:数据结构的精妙之处
前言 在计算机科学中,数据结构是构建和组织数据的基础,它们是解决复杂问题的关键。然而,在众多数据结构中,链表(Linked List)因其独特的特点和广泛的应用而备受关注。本文将带您深入探讨链表的概念、种类、…...

Java监听mysql的binlog 报错解决办法
报错:com.github.shyiko.mysql.binlog.network.AuthenticationException: Client does not support authentication protocol requested by server; consider upgrading MySQL client 解决方案:在mysql中执行以下命令 alter user rootlocalhost identi…...

Javascript 中的 debugger 拦截
debugger 指令,一般用于调试,在如浏览器调试执行环境中,可以在 JavaScript 代码中产生中断。 如果想要拦截 debugger,是不容易的,常用的函数替代、proxy 方法均对它无效,如: window.debugger …...

深入Golang之Mutex
深入Golang之Mutex 基本使用方法 可以限制临界区只能同时由一个线程持有。 直接在流程结构中使用 lock、unlock嵌入到结构中,然后通过结构体的 mutex 属性 调用 lock、unlock嵌入到结构体中,但是是直接在需要锁定的资源方法中使用,让外界无…...

高并发内存池项目(C++实战项目)
项目介绍 项目来源 本项目实现了一个高并发内存池,参考了Google的开源项目tcmalloc实现的简易版;其功能就是实现高效的多线程内存管理。由功能可知,高并发指的是高效的多线程,而内存池则是实现内存管理的。 tcmalloc源码 ▶项…...

G. The Morning Star - 思维
分析: 直接暴力就会tle,不知道怎么下手,可以统计八个方向一条线上的所有坐标,这些坐标一定可以放在一起满足,分析都有哪些线,当横坐标相同时会有竖着的一条线都可以,也就是x c,当纵…...

应急物资管理系统|智物资DW-S300提升应急响应能力
项目背景 智慧应急物资管理系统(智装备DW-S300)是一套成熟系统,依托互3D技术、云计算、大数据、RFID技术、数据库技术、AI、视频分析技术对RFID智能仓库进行统一管理、分析的信息化、智能化、规范化的系统。 本项目采用东识智慧应急物资管理…...

AI人员打架识别算法
AI打架识别算法通过yolov8网络模型算法框架,AI打架识别算法识别校园打架斗殴行为,发现立即打架斗殴行为算法会立即抓拍告警推送打架事件信息。目标检测架构分为两种,一种是two-stage,一种是one-stage,区别就在于 two-s…...

NSS [NUSTCTF 2022 新生赛]Ezjava1
NSS [NUSTCTF 2022 新生赛]Ezjava1 题目描述:你能获取flag{1}吗 开题,一眼java web中的index.jsp。 默认index.jsp中的body内容是$END$ 附件jar包导入IDEA,会自动反编译。看看源码。 附件结构大致如此。主要看classes.com.joe1sn中的代码就…...

【Go 基础篇】探索Go语言中Map的神奇操作
嗨,Go语言的学习者们!在编程世界中,Map是一个强大而又有趣的工具,它可以帮助我们高效地存储和操作键值对数据。Map就像是一本字典,可以让我们根据关键字(键)快速找到对应的信息(值&a…...

第6篇:ESP32连接无源喇叭播放音乐《涛声依旧》
第1篇:Arduino与ESP32开发板的安装方法 第2篇:ESP32 helloword第一个程序示范点亮板载LED 第3篇:vscode搭建esp32 arduino开发环境 第4篇:vscodeplatformio搭建esp32 arduino开发环境 第5篇:doit_esp32_devkit_v1使用pmw呼吸灯实验 D5连接喇叭正极,GND连接喇叭负…...

Linux用户组管理学习
1.创建一个用户组...

【知识分享】C语言应用-易错篇
一、C语言简介 C语言结构简洁,具有高效性和可移植性,因此被广泛应用。但究其历史的标准定义,C语言为了兼容性在使用便利性作出很大牺牲。在《C陷阱与缺陷》一书中,整理出大部分应用过程中容易出错的点,本文为《C陷阱与…...

六、Json 数据的交互处理
文章目录 一、JSON 数据的交互处理1、为什么要使用 JSON2、JSON 和 JavaScript 之间的关系3、前端操作 JSON3.1 JavaScript 对象与 JSON 字符串之间的相互转换 4、JAVA 操作 JSON4.1 Json 的解析工具(Gson、FastJson、Jackson)4.2 ResponseBody 注解、Re…...

企业微信cgi-bin/gateway/agentinfo接口存在未授权访问漏洞 附POC
文章目录 企业微信cgi-bin/gateway/agentinfo接口存在未授权访问漏洞 附POC1. 企业微信cgi-bin/gateway/agentinfo接口简介2.漏洞描述3.影响版本4.fofa查询语句5.漏洞复现6.POC&EXP7.整改意见8.往期回顾 企业微信cgi-bin/gateway/agentinfo接口存在未授权访问漏洞 附POC 免…...

【数据结构与算法 模版】高频题刷题模版
废话不多说,喊一句号子鼓励自己:程序员永不失业,程序员走向架构!本篇Blog的主题是【】,使用【】这个基本的数据结构来实现,这个高频题的站点是:CodeTop,筛选条件为:目标公…...

EMQ X支持哪些认证方式?
EMQ X 中的认证指的是当一个客户端连接到 EMQ X 的时候,通过服务器端的配置来控制客户端连接服务器的权限。 EMQ X 的认证支持包括两个层面: MQTT 协议本身在 CONNECT 报文中指定用户名和密码,EMQ X 以插件形式支持基于 Username、 ClientI…...

java八股文面试[JVM]——JVM内存结构2
知识来源: 【2023年面试】JVM内存模型如何分配的_哔哩哔哩_bilibili...

《C和指针》笔记14: 作用域和存储类型总结(例子说明)
文章目录 题目答案解释总结 本文是作用域和存储类型的总结,以一个例子来说明,如果不看解释可以很直接地回答每一条语句的作用域和存储类型,那么说明已经很熟练地掌握这个知识点了。 关于作用域和存储类型可以参考我前面的博客: …...

Linux之系统操作参数详解
Linux之系统操作参数详解 date //显示当前日期 日期格式化 %Y year年 %y 年份(以00-99来表示) %j 该年中的第几天 %m month月 (01…12) %w 该周的天数,0代表周日,1代表周一 %D 日期(含年月日) %d day of month (e.g., 01) %T 时间(含时分秒࿰…...

datax 使用
环境准备 List itemLinuxJDK(1.8以上,推荐1.8)Python(2或3都可以)Apache Maven 3.x (Compile DataX) 下载 wget https://datax-opensource.oss-cn-hangzhou.aliyuncs.com/202308/datax.tar.gz建立datax 用户 useradd datax ; echo "datax" | passwd -…...

【C/C++】#define宏替换高级用法
创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下♡>𖥦<)!! 主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步! 🔥c系列专栏:C/C零基础到精通 🔥 给大…...

Android 之 传感器专题 (4) —— 其他传感器了解
本节引言: 在上一节的结尾说了,传感器部分因为笔者没怎么玩过,本节就简单的把剩下的几个常用的 传感器介绍一遍,当作科普,以后用到再慢慢研究~ 1.磁场传感器(Magnetic field sensor) 作用:该传感器主要用…...

【高级搜索】双向广搜,A*,IDDFS,IDA *算法总结 (terse版)
一、双向广搜 双向广搜就是从起点和终点同时往中间搜的一个算法。 注意事项: 在搜索过程中,同一层次下的顺序应该为:搜完一边所有的当前深度的子节点,在搜索另一边。 队列使用 (1)合用…...