java工具类开发之json工具类JsonUtils和写数据回页面工具类ResponseUtils

2023-12-06 06:20

本文主要是介绍java工具类开发之json工具类JsonUtils和写数据回页面工具类ResponseUtils,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java工具类开发之json工具类JsonUtils和写数据回页面工具类ResponseUtils

     采用Java开发应用软件,如果数据库层采用蛋疼的纯生jdbc时候,需要考虑到将查询数据库得到的结果集resultRest进行转换为JsonArray并将其返回到页面!当然了,现在对于“将查询数据库得到的结果集resultRest转换为JsonArray”已经有很多json的库来解决了,譬如json-lib、gson、jackson、fastjson等等,本文介绍的正是json-lib这种比较纯洁的库来处理resultSet,晚点再介绍jackson 和 fastjson。对于“将后台处理后的结果返回到页面”,我们需要自己封装一个:可用于ajax异步调用的!

     首先介绍一下JsonUtils,对于JsonUtils,因为我们是用来处理resultSet的,所以,我们首先需要有一个DBConnUtils来获取数据库链接,以便后面我们查询数据库得到ResultSet,最终用于测试。首先我需要加入c3p0的jar包和mysql的驱动jar包,因为我们用到的就是采用c3p0来获取数据库链接并进行相关的数据库操作的!

     当然啦,除此之外,我们需要加入json-lib的jar包:要注意加全!!!!不然会出现很多蛋疼的问题!!可以来这里下载本文涉及到的工具类开发的时候需要的jar包: jar包下载

    下面是截图:其中 db.properties是一个属性属性文件,其内容可以在前一篇博文看到!  右边是数据库表tb_user表中的内容,下面会用到!!

                                          

     

     下面是DBConnUtils工具类的内容:

<span style="font-size:18px;">package com.steadyjack.utils;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;/*** @author 钟林森* 获取数据库链接工具类*/
public class DBConnUtils {private static String driver=null;private static String url=null;  private static String user=null;private static String password=null;  //采用读取属性配置文件工具类PropertiesUtils.java读取相关属性值static{driver=PropertiesUtils.readProperty("driver");url=PropertiesUtils.readProperty("url");user=PropertiesUtils.readProperty("user");password=PropertiesUtils.readProperty("password");}public static Connection getConn(){  //加载驱动程序  try {  Class.forName(driver);  } catch (ClassNotFoundException e) {  e.printStackTrace();  }  //链接数据库  Connection conn=null;  try {  conn=DriverManager.getConnection(url, user, password);  if (!conn.isClosed()) {  System.out.println("连接数据库成功");  }  } catch (SQLException e) {  System.out.println("链接数据库失败: "+e.getMessage());  }  return conn;  }  
}
</span>

       下面是JsonUtils的代码,具体我就不多解释,我在代码已经解释的很清楚了(其实:得到的ResultSet就是一个二维表或者说是矩阵,本质是采用行列先后访问:先遍历行,再遍历每一行对应的每一列的名称和数据!)

package com.steadyjack.utils;import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.util.Date;import net.sf.json.JSONArray;
import net.sf.json.JSONObject;/*** @author 钟林森* 用于处理查询得到的ResultSet转变为JsonArray*/
public class JsonUtils {/*** 将查询数据库得到的结果集转化为JsonArray,供前端使用* @author 钟林森* @param rs 查询数据库得到的结果集:其实就一个矩阵(二维表)* @return * @throws Exception* * 简单的理解:"先遍历行,对于每一行获取每一列的列名以及改行该列对于的值" ,所以需要获取有多少列,以及每一列的列名(元数据ResultSetMetaData)*/public static JSONArray formatRsToJsonArray(ResultSet rs) throws Exception{//先获取元数据操作对象:ResultSetMetaData 以及  一共有多少列ResultSetMetaData rsmd=rs.getMetaData();int columnCount=rsmd.getColumnCount();//jsonArray存放的是每个jsonObject:其实就是resultSet的一行数据JSONArray jsonArray=new JSONArray();//开始遍历每一行while(rs.next()){JSONObject mapOfColValue=new JSONObject();for(int i=1;i<=columnCount;i++){Object object=rs.getObject(i);//由于数据库表字段可能含有日期date,所以需要进行特殊处理if (object instanceof Date) {mapOfColValue.put(rsmd.getColumnName(i), DateUtils.dateToStr((Date)object, "yyyy-MM-dd"));}else{mapOfColValue.put(rsmd.getColumnName(i), object);}}//遍历获取完一条数据就添加到jsonArray中jsonArray.add(mapOfColValue);}return jsonArray;}}

      这篇博文我觉得它写得比较详细: json学习-JSONArray的应用,我参考了一下;下面是JsonUtils和DBConnUtils的单元测试类:

package com.steadyjack.testUtils;import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;import net.sf.json.JSONArray;import org.junit.Test;import com.steadyjack.utils.DBConnUtils;
import com.steadyjack.utils.JsonUtils;/*** @author 钟林森* */
public class JsonUtilsTest {@Testpublic void test() throws Exception{Connection connection=DBConnUtils.getConn();System.out.println(connection);String sql="SELECT id,name,address,last_name FROM tb_user";PreparedStatement pstmt=connection.prepareCall(sql);ResultSet rs=pstmt.executeQuery();JSONArray jsonArray=JsonUtils.formatRsToJsonArray(rs);//JsonArray 转换为数组Object[] obj=JSONArray.fromObject(jsonArray.toString()).toArray();  for(int i=0;i<obj.length;i++){  System.out.println(obj[i]);  }	  System.out.println();}}

     得到的结果如下截图:



      最后,介绍一个ResponseUtils工具类,用于将后台处理相关业务逻辑后得到的最终结果返回到前端,这个前端可以使页面,也可以js异步调用的结果!这个的话,就没写js调用进行测试!!

package com.steadyjack.utils;import java.io.PrintWriter;
import javax.servlet.http.HttpServletResponse;/*** 将后台处理完的结果写回前端页面,如jsp页面;* 或者可用于在ajax异步调用后台方法,该方法处理完相应业务逻辑之后将结果返回,这个结果即通过这个工具类实现* @author 钟林森*/
public class ResponseUtil {public static void write(HttpServletResponse response,Object o)throws Exception{response.setContentType("text/html;charset=utf-8");PrintWriter out=response.getWriter();out.println(o.toString());out.flush();out.close();}
}

          本文就介绍到这里了!!!

这篇关于java工具类开发之json工具类JsonUtils和写数据回页面工具类ResponseUtils的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/u013871100/article/details/52039089
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/460767

相关文章

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Spring Cache注解@Cacheable的九个属性详解

《SpringCache注解@Cacheable的九个属性详解》在@Cacheable注解的使用中,共有9个属性供我们来使用,这9个属性分别是:value、cacheNames、key、key... 目录1.value/cacheNames 属性2.key属性3.keyGeneratjavascriptor

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

java中XML的使用全过程

《java中XML的使用全过程》:本文主要介绍java中XML的使用全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录什么是XML特点XML作用XML的编写语法基本语法特殊字符编写约束XML的书写格式DTD文档schema文档解析XML的方法​​DOM解析XM