Flex通过Spring aop拦截后台Service的报错信息 在前台、MyEclipse控制台、Logger展示

本文主要是介绍Flex通过Spring aop拦截后台Service的报错信息 在前台、MyEclipse控制台、Logger展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先说明要实现的效果:

Flex通过RemoteObject调用任何的后台Service时的报错信息在前台、MyEclipse控制台、Logger展示出来。

 

实现途径:

Spring AOP切入所有的Spring  的 Service bean,

用一个统一的Java类来控制异常的输出。

实现步骤:

1、通过spring的aop统一拦截Exception抛出自定义异常

详情请看:

spring AOP的异常拦截

http://blog.csdn.net/truelove12358/article/details/39396489

 

测试可以使用的配置:

<bean id="exceptionLog" class="net.chinanets.utils.AopExceptionHandler"></bean>
    <!-- beanName自动代理 -->
 <bean id="logAdvice"
  class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
  <property name="beanNames">
   <list>
    <value>*Service</value>
   </list>
  </property>
  <property name="interceptorNames">
  <list>
   <value>exceptionLog</value>
  </list>
  </property>
 </bean>

其中 net.chinanets.utils.AopExceptionHandler

package net.chinanets.utils;

import java.lang.reflect.Method;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.springframework.aop.ThrowsAdvice;

import flex.messaging.MessageException;


/**
 * @author: duzj
 * @Action: 负责异常处理的Advice 使用Throw通知类型来实现Advice
 */
public class AopExceptionHandler implements ThrowsAdvice
{
 /**
  * 重写afterThrowing()方法
  *
  * @param method 执行方法
  * @param args 执行参数
  * @param target 执行实体
  * @param subclass 父类
  * @throws Throwable 异常
  */
 private Logger logger = Logger.getLogger(this.getClass().getName());
 public void afterThrowing(Method method, Object[ ] args, Object target, Throwable subclass) throws Throwable {
  String argParas = "";
  
  System.err.println("产生异常的方法名称:  " + method.getName());
  for(Object o:args){
   argParas += o.toString()+",";
   System.out.println("方法的参数:   " + o.toString());
  }
  System.out.println("代理对象:   " + target.getClass().getName());
  System.out.println("抛出的异常:    " + subclass.getMessage()+">>>>>>>"
    + subclass.getCause());
  System.out.println("异常详细信息:   "+subclass.fillInStackTrace());
  
  String exMsg = Level.ERROR+": 执行 " + method.getName() + "("+argParas.substring(0,argParas.length() - 1)  + ") 时有异常抛出!" + subclass;
  logger.log( Level.ERROR,exMsg);
  
 // throw new Exception(exMsg);
  MessageException mse = new MessageException();
  mse.setCode(subclass.fillInStackTrace().toString()); 
  mse.setMessage(exMsg); 
  mse.setDetails("Flex 调用 Service 中的方法报错,请检查传入的参数或调用的方法!"); 
  mse.setRootCause(subclass.getCause()); 
  throw mse;
 }

}
2、

MessageException mse = new MessageException();
  mse.setCode(subclass.fillInStackTrace().toString()); 
  mse.setMessage(exMsg); 
  mse.setDetails("Flex 调用 Service 中的方法报错,请检查传入的参数或调用的方法!"); 
  mse.setRootCause(subclass.getCause()); 
  throw mse;

 

MessageException的解释请看:

Flex异常处理 机制 设计

http://blog.csdn.net/truelove12358/article/details/39398239

简单的说:MessageException就是Flex提供的一个Java Exception 到 Flex Exception的映射。

 

这样就达到了目的,截图:

这篇关于Flex通过Spring aop拦截后台Service的报错信息 在前台、MyEclipse控制台、Logger展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/927883

相关文章

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows