一、背景
既然使用了EasyUI那么,基本上都是通过JSON来进行数据交换。那么问题就来了,struts2可以通过配置,发生异常时,可以转发到相应错误页面,并显示错误信息。我们不需要返回错误页面啊!那如何返回一个JSON字符串呢?
struts.xml配置文件:
<package name="xxx-default" extends="json-default"> <global-results> <result name="error">/WEB-INF/jsp/common/error.jsp</result> </global-results> <global-exception-mappings> <exception-mapping result="error" exception="java.lang.Exception"> </exception-mapping>
</global-exception-mappings> </package>
用户列表JSP页面:
<table id="user_dg" class="easyui-datagrid" data-options="url:'${pageContext.request.contextPath}/user_list.do', fit:true, rownumbers:true, toolbar:'#user_toolbar', singleSelect:true, pagination:true, pageSize:20, loadFilter:function(result){ if(!result.rows||!result.total){ if(result.errorMsg){ $.messager.alert('错误提示','获取用户列表信息失败!错误原因:<br/>'+result.errorMsg,'error'); }else{ $.messager.alert('错误提示','获取用户列表信息失败!','error'); } return {total:0,rows:[]}; }else{ return result; } }"> <thead> <tr> <th data-options="field:'id',width:50">id</th> <th data-options="field:'username',width:150,sortable:true">用户名</th> <th data-options="field:'name',width:150,sortable:true">姓名</th> <th data-options="field:'email',width:200">邮箱地址</th> <th data-options="field:'mobile',width:200">手机</th> <th data-options="field:'birthday',width:150,sortable:true">生日</th> <th data-options="field:'options',width:150">操作</th> </tr> </thead> </table>
如果没有异常那么正常返回的JSON字符串格式为{"total":总共记录数,"rows",[{用户信息1},{用户信息2}...]}
用户信息中的JSON字段名称与th 的 data-options="field:'字段名'.. 一致
原先可能你会这么写错误页面:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@taglib prefix="s" uri="/struts-tags"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>错误页面</title> </head> <body> 错误信息: <s:property value="exception.message" /> </body> </html>
二、思路
思路其实很简单,指定的错误页面是JSP,那么我们可以让JSP页面显示JSON字符串不就行了么。
二、实施
有了,思路就要实施了,现在你只需要让错误页面,返回一个包含错误信息的JSON字符串
<%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@taglib prefix="s" uri="/struts-tags"%> {"errorMsg":"<s:property value="exception.message" />"}
来试试看,故意抛出个异常,
/** * 用户列表JSON * * @return */ public String list() throws Exception { dataMap.clear(); // 故意抛出个异常,看看是否凑效 if (true) throw new HibernateException(new RuntimeException(new Exception("[这是异常啊!!!!}\"..._}]"))); int total = userService.countAll(); Collection<User> users = userService.findPageByHQLQuery( getStartIndex(), getPageSize()); log.debug("用户数:" + total); dataMap.put("total", total); // 过滤集合中元素的属性 JsonConfig jsonConfig = new JsonConfig(); jsonConfig.registerPropertyExclusions(User.class, new String[] { "roles", "OPTIONS" }); dataMap.put("rows", JSONArray.fromObject(users, jsonConfig)); return "list"; }
可以显示错误信息,OK,这样就搞定了,O(∩_∩)O~
注释掉看看原来的信息能不能正常显示,:
//if (true) // throw new HibernateException(new RuntimeException(new //Exception("[这是异常啊!!!!}\"..._}]")));
还好可以正常显示。。。O(∩_∩)O~
我这边对异常信息处理比较粗糙,而且错误信息也不够友好,用户看到的话,肯定不知道是什么意思,这是问题所在,大家如果有什么更好的方法,更优雅的方法,让struts2处理异常信息,而且这个信息能够比较友好的,请赐教,欢迎讨论。。。
相关推荐
Struts2、EasyUI、Ajax 和 JSON 是现代Web开发中常用的技术栈,它们结合使用可以构建出高效、交互性强的用户界面。以下是对这些技术及其在用户登录验证中的应用的详细解释。 **Struts2** 是一个基于MVC(Model-View...
在"struts2+ajax+easyui+json+datagrid"的场景中,Struts2主要负责处理用户的请求,执行业务逻辑,并返回相应的响应数据。 **Ajax** (Asynchronous JavaScript and XML) 是一种在无需刷新整个页面的情况下更新部分...
- **Action处理**:Struts2 Action接收到请求,调用后台服务处理数据,如从数据库中获取或更新信息。 - **JSON响应**:Action返回JSON格式的结果,便于前端解析和显示。 - **前端交互**:EasyUI使用jQuery的ajax...
标题 "JQuery EasyUI 整合struts2 代码下载" 涉及到的是一个Web开发中的技术组合,主要集中在前端的JQuery EasyUI框架与后端的Struts2框架的集成应用。JQuery EasyUI是一个基于jQuery的UI库,提供了丰富的组件,如...
- 错误处理:在整合过程中可能出现各种异常,如类型转换异常、找不到bean等,需要正确处理这些异常,提供友好的错误信息。 - 安全性:考虑到Struts2的安全问题,如Struts2的OGNL漏洞,需要及时更新修复,同时对...
使用Struts2和jQuery EasyUI实现简单CRUD系统,从零开始,从基础的EasyUI与Struts2的使用json格式进行交互开始。
总的来说,"struts2+spring+mybatis+easyui"的实现是一个标准的Java Web项目结构,它利用Maven进行构建管理,通过整合四个组件,实现了后端的业务逻辑处理、数据访问和前端的用户界面展示。这种架构在实际开发中具有...
总之,“struts2+easyui+uploadfye文件上传”项目是一个结合了后端处理、前端展示和异步上传功能的典型示例,它展示了如何利用现有技术解决实际开发中的问题,对于学习和理解这些技术的集成应用具有很高的参考价值。
Struts2.3.1与EasyUI1.2.5的整合是Web开发中的一个常见实践,主要用于构建高效、易用且美观的管理界面。Struts2是一个强大的MVC(Model-View-Controller)框架,它提供了良好的架构支持,帮助开发者实现业务逻辑与...
Struts2、JSON、jQuery 和 EasyUI 是四个在Web开发领域广泛应用的技术,它们共同构建了一个高效、用户友好的项目框架。下面将详细解释这些技术及其在项目中的作用。 **Struts2** Struts2 是一个基于MVC(Model-View...
### Struts2 结合 EasyUI 实现增删改分页排序 #### 一、概述 在Web开发领域,Struts2 和 EasyUI 是两个非常重要的框架和技术。Struts2 是一款基于MVC模式的Java Web应用程序框架,它帮助开发者构建灵活、可扩展的...
【作品名称】:基于java+struts2+easyui+Mysql实现的课程辅助系统含(课程管理,学生管理,论坛答疑) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训...
同时,Struts2与Spring的整合使得我们可以方便地利用Spring的bean管理功能。 3. EasyUI: EasyUI是基于jQuery的前端UI库,它提供了丰富的组件,如表格、树形控件、对话框等,使得页面布局和交互设计更为便捷。在本...
json-lib是一个用于处理JSON格式数据的Java库,在Struts2和EasyUI之间进行数据传输时,可能会用到它将Java对象转换为JSON字符串。 整合这些技术的过程包括: 1. 配置Struts2:在struts.xml文件中定义Action和结果...
在本文中,我们将深入探讨如何将jQuery EasyUI与Struts2框架进行整合,特别是关注属性驱动的方式。jQuery EasyUI是一个基于jQuery的前端UI库,它提供了丰富的组件和易于使用的API,使得开发人员能够快速构建美观的...
系统搭建使用struts2 + spring + hibernate + easyui 整合的, 功能包括: 分页查询,自定义页面数据显示量,用户名模糊搜索,创建时间段,更新时间段内用户信息搜索,双击行进行编辑,多行选中删除,右键菜单已经写好...
SSM(Spring、Struts2、MyBatis)框架整合是Java Web开发中常见的技术栈,结合EasyUI前端框架,可以构建出功能丰富且用户体验良好的Web应用。在本项目"maven-ssm-web-demo"中,我们将深入探讨这个集成方案。 首先,...
本示例"Spring+Hibernate+Struts2+EasyUI基本权限管理框架"提供了一个全面的解决方案,旨在帮助初学者理解和掌握这些核心技术的集成与应用。下面将分别介绍这四个主要组件以及它们在权限管理中的作用。 1. **Spring...
- 错误处理:良好的错误处理机制是必要的,如使用异常捕获并在前端友好地展示错误信息。 总的来说,"Struts2与EasyUI和DBUtils的一个简单的小项目"旨在帮助开发者理解这三个组件的集成使用,以及如何通过它们实现...
在本文中,我们将探讨如何使用Struts2和jQuery EasyUI框架创建一个简单的CRUD(创建、读取、更新、删除)系统。首先,我们需要理解这两个技术的基础概念。 Struts2是一个基于MVC(Model-View-Controller)架构的...