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{driveradProperty("driver");urladProperty("url");useradProperty("user");passwordadProperty("password");}public static Connection getConn(){ //加载驱动程序 try { Class.forName(driver); } catch (ClassNotFoundException e) { e.printStackTrace(); } //链接数据库 Connection conn=null; try { connConnection(url, user, password); if (!conn.isClosed()) { System.out.println("连接数据库成功"); } } catch (SQLException e) { System.out.println("链接数据库失败: "Message()); } return conn; }
}
</span>
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 rsmdMetaData();int columnCountColumnCount();//jsonArray存放的是每个jsonObject:其实就是resultSet的一行数据JSONArray jsonArray=new JSONArray();//开始遍历每一行()){JSONObject mapOfColValue=new JSONObject();for(int i=1;i<=columnCount;i++){Object objectObject(i);//由于数据库表字段可能含有日期date,所以需要进行特殊处理if (object instanceof Date) {mapOfColValue.ColumnName(i), DateUtils.dateToStr((Date)object, "yyyy-MM-dd"));}else{mapOfColValue.ColumnName(i), object);}}//遍历获取完一条数据就添加到jsonArray中jsonArray.add(mapOfColValue);}return jsonArray;}}
package stUtils;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 connectionConn();System.out.println(connection);String sql="SELECT id,name,address,last_name FROM tb_user";PreparedStatement pstmt=connection.prepareCall(sql);ResultSet rsuteQuery();JSONArray jsonArray=JsonUtils.formatRsToJsonArray(rs);//JsonArray 转换为数组Object[] obj=JSONArray.String()).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 outWriter();out.String());out.flush();out.close();}
}
本文就介绍到这里了!!!
本文发布于:2024-02-04 13:42:40,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170708551556081.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |