我们上一篇文章已经将LigerUI表格的页面效果以及前端如何加载Json进行了介绍,下面我们来看下后台是如何处理得到Json的。
上一篇文章中,我们通过url“statisticalQuery_list.action”跳转到这个StatisticalQueryAction类的list方法,从前台url如何跳转到这个action类的list方法,这是我们在l文件中配置的,如下:
<pre name="code" class="html"><!--统计查询 -->
<action name="statisticalQuery_*" class="statisticalQueryAction"method="{1}"><result name="tolist">/admin/jsp/StatisticalQuery/StatisticalQuery1.jsp</result><result name="forupdatelist">/admin/jsp/StatisticalQuery/StatisticalQuery.jsp</result><result name="toDetail">/admin/jsp/StatisticalQuery/detailInfo.jsp</result><interceptor-ref name="checkAdminPrivilege" /><interceptor-ref name="defaultStack" /></action>
下面我们先来看下这个类的用到的方法:
//前台查询的条件private String keyWord;public String getKeyWord() {return keyWord;}public void setKeyWord(String keyWord) {this.keyWord = keyWord;}/*** * @MethodName : list* @Description : 取到所有数据,让表格显示* @return* @throws Exception*/public String list() throws Exception {try {String page = Request().getParameter("page");String pagesize = Request().getParameter("pagesize");String strWhere="";int statNum = (Integer.parseInt(page) - 1) * Integer.parseInt(pagesize)+1;int endNum=Integer.parseInt(page)*Integer.parseInt(pagesize);if (StringUtils.isNotBlank(keyWord)) {strWhere = java.URLDecoder.decode(keyWord, "UTF-8");}System.out.println(strWhere);//从视图中取到的数据,需要转换一下//查询记录数List<StatisticalQueryView> statisticalQueryViewsCount =statisticalQueryService.findAllBypage(strWhere);//分页查询数据List<StatisticalQueryView> statisticalQueryViews =statisticalQueryService.findAllBypage(statNum,endNum,strWhere);//将视图集合转化成普通list集合然后转jsonList<StatisticalQuery> statisticalQueries=viewNormal(statisticalQueryViews);//将后台出来的实体集合转化为前台表格可以接收的特殊形式的jsonString resultJsonJsonGirdN(statisticalQueries,statisticalQueryViewsCount);System.out.println("resultJson"+resultJson);Response(), resultJson);} catch (Exception e) {e.printStackTrace();}return null;}/*** * @MethodName : viewNormal* @Description : 将视图集合转化成普通list集* @param statisticalQueryViews* @return*/public List<StatisticalQuery> viewNormal(List<StatisticalQueryView> statisticalQueryViews){//将视图list集合转化成普通集合List<StatisticalQuery> statisticalQueries=new ArrayList<StatisticalQuery>();StatisticalQuery statisticalQuery=null;try {for (int i = 0; i < statisticalQueryViews.size(); i++) {statisticalQuery=new StatisticalQuery();statisticalQuery(i).getStatisticalQuery();statisticalQueries.add(statisticalQuery);}} catch (Exception e) {e.printStackTrace();} return statisticalQueries;
}
/*** * @Title: outJson* @Description: 输出结果到前台* @param @param response* @param @param result 设定文件* @return void 返回类型* @throws*/private void outPrint(HttpServletResponse response, String data) {String encoding = "UTF-8";String contentType = "application/json;charset=UTF-8";response.setContentType(contentType);response.setCharacterEncoding(encoding);try {PrintWriter out = Writer();out.print(data);out.flush();out.close();} catch (Exception e) {System.out.Message());}}
我们先解释上面的这三个方法,首先第一个“list“方法是通过“keyWord”属性的依赖注入得到前台传过来的条件,然后通过条件查询得到一个视图的list集合,因为前台其它特殊需求,所以用到了第二个方法“viewNormal”将视图list集合转化我们想要的集合;第三个方法是将Json数据传输到前台。
下面我们就重点来介绍下我们是如何将实体集合转为前台可接收的Json的,我们是调用JsonUtils类的toJsonGirdN方法来转化的。在这里我们用到了Gson,Gson 是 Google 提供的用来在 Java 对象和 JSON 数据之间进行映射的 Java 类库。
下面看下我们的这个类:
package cn.bjjczb.ybyy.util;
import flect.Type;import java.util.HashMap;
import java.util.List;
import java.util.Map;CORBA.PRIVATE_MEMBER;
import cn.bjjczb.ybyy.domain.Role;le.gson.Gson;
le.gson.JsonNull;
flect.TypeToken;public class JsonUtils {private static Gson gson = new Gson();private JsonUtils(){}/*** * @MethodName : toJsonGird* @Description : 将集合转化为ligerUI前台需求的表格形式的json串,zh新添加* @param list* @return*/@SuppressWarnings("unchecked")public static String toJsonGirdN(List list,List list2){String result = null;try {//将集合放到map中转化为json,仍然不是我们想要的,不过已经很接近了Map listMap = new HashMap();listMap.put("Rows", list);String jsonJson(listMap) ; //System.out.println(json); //结果为:{"Rows":[{"a":"测试1","b":"纯测试1"},{"a":"测试2","b":"纯测试2"},{"a":"测试3","b":"纯测试3"},{"a":"测试3","b":"纯测试3"}]}String total= String.valueOf(list2.size()); String totalReplace="{"Total":"+total+","Rows""; resultplace("{"Rows"", totalReplace);//System.out.println(result); } catch (Exception e) {e.printStackTrace();}finally{return result;}}
}
在上面的这个类中,我们首先将我们要转化为json的list实体集合放到map中,然后利用gson类的toJson方法将map转为Json,然后将Json进一步转化即可得到我们前台表格需要加载的Json数据。
下面我们将常用到的对象转化为Json和Json转为对象的方法一并给大家。
/*** * @MethodName : toJson* @Description : 将对象转换为JSON串,* 此方法能够满足大部分需求* @param src:将要被转化的对象* @return:*/public static String toJson(Object src) {if (src == null) {Json(JsonNull.INSTANCE);}Json(src);}/*** * @MethodName : fromJson1* @Description : 用来将JSON串转换为对象,* 此方法不可用来转带泛型的List* @param <T>* @param json* @param classOfT* @return*/public static<T> Object fromJson1(String json,Class<T> classOfT){return gson.fromJson(json, (Type) classOfT);}/*** 测试将json串转换为对象,转泛型不可用* @MethodName : test* @Description : 此方法为我做的测试Role为实体*/public void test(){Role role = new Role();String json="";JsonUtils.fromJson1(json, Class());}/*** * @MethodName : fromJson2* @Description : 此方法用来将JSON串转化为对象,此方法可以用来转带泛型的List* Type为new TypeToken<List<T>>()* {}.getType(),其它类也可以用此方法调用,* 就是将List<T>替换为你想要转成的类* @param json* @param typeOfT* @return*/public static Object fromJson2(String json, Type typeOfT) {return gson.fromJson(json, typeOfT);}/*** 测试将json转换为泛型对象* @MethodName : test1* @Description : 此方法为我做的测试Role为实体*/public void test1(){Type roles =new TypeToken<List<Role>>(){}.getType();String json="";JsonUtils.fromJson2(json,roles);}
上面这几个方法是将对象转为Json已经Json转为对象,包括Json转普通对象和Json转泛型对象,其中test和test1方法是我做的测试,大家可以根据需要进行扩展。
关于Json和对象之间的互相转化第三方类库还是很多的,gson只是其中的一种,不过他们也都大同小异,用熟了一个,其它的也就都一样了。
本文发布于:2024-02-04 22:47:10,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170718117560414.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |