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 {
	
	@Test
	public 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();
	}
}

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

  • 1
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

修罗debug

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值