前端传参对象套对象的格式,后端进行解析并存入数据库
项目场景:
在一些小程序中会涉及到一个表单中的一个数组对象中夹杂着另一个对象数据,这个被夹杂的数据是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 免…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...

超短脉冲激光自聚焦效应
前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应,这是一种非线性光学现象,主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场,对材料产生非线性响应,可能…...

Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动
一、前言说明 在2011版本的gb28181协议中,拉取视频流只要求udp方式,从2016开始要求新增支持tcp被动和tcp主动两种方式,udp理论上会丢包的,所以实际使用过程可能会出现画面花屏的情况,而tcp肯定不丢包,起码…...

简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

循环冗余码校验CRC码 算法步骤+详细实例计算
通信过程:(白话解释) 我们将原始待发送的消息称为 M M M,依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)(意思就是 G ( x ) G(x) G(x) 是已知的)࿰…...

从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
【磁盘】每天掌握一个Linux命令 - iostat
目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat(I/O Statistics)是Linux系统下用于监视系统输入输出设备和CPU使…...

cf2117E
原题链接:https://codeforces.com/contest/2117/problem/E 题目背景: 给定两个数组a,b,可以执行多次以下操作:选择 i (1 < i < n - 1),并设置 或,也可以在执行上述操作前执行一次删除任意 和 。求…...

Linux nano命令的基本使用
参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时,显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...

【Linux系统】Linux环境变量:系统配置的隐形指挥官
。# Linux系列 文章目录 前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变量的生命周期 四、环境变量的组织方式五、C语言对环境变量的操作5.1 设置环境变量:setenv5.2 删除环境变量:unsetenv5.3 遍历所有环境…...