前端传参对象套对象的格式,后端进行解析并存入数据库
项目场景:
在一些小程序中会涉及到一个表单中的一个数组对象中夹杂着另一个对象数据,这个被夹杂的数据是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 免…...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...

使用分级同态加密防御梯度泄漏
抽象 联邦学习 (FL) 支持跨分布式客户端进行协作模型训练,而无需共享原始数据,这使其成为在互联和自动驾驶汽车 (CAV) 等领域保护隐私的机器学习的一种很有前途的方法。然而,最近的研究表明&…...

【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

【项目实战】通过多模态+LangGraph实现PPT生成助手
PPT自动生成系统 基于LangGraph的PPT自动生成系统,可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析:自动解析Markdown文档结构PPT模板分析:分析PPT模板的布局和风格智能布局决策:匹配内容与合适的PPT布局自动…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...

什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...

听写流程自动化实践,轻量级教育辅助
随着智能教育工具的发展,越来越多的传统学习方式正在被数字化、自动化所优化。听写作为语文、英语等学科中重要的基础训练形式,也迎来了更高效的解决方案。 这是一款轻量但功能强大的听写辅助工具。它是基于本地词库与可选在线语音引擎构建,…...

JVM 内存结构 详解
内存结构 运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器: 线程私有,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 每个线程都有一个程序计数…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...

Rust 开发环境搭建
环境搭建 1、开发工具RustRover 或者vs code 2、Cygwin64 安装 https://cygwin.com/install.html 在工具终端执行: rustup toolchain install stable-x86_64-pc-windows-gnu rustup default stable-x86_64-pc-windows-gnu 2、Hello World fn main() { println…...