真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java利用spring注解實(shí)現(xiàn)處理異常AOP

java利用spring注解實(shí)現(xiàn)處理異常AOP?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

創(chuàng)新互聯(lián)是專業(yè)的息烽網(wǎng)站建設(shè)公司,息烽接單;提供網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行息烽網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

一、前言

項(xiàng)目剛剛開(kāi)發(fā)的時(shí)候,并沒(méi)有做好充足的準(zhǔn)備。開(kāi)發(fā)到一定程度的時(shí)候才會(huì)想到還有一些問(wèn)題沒(méi)有解決。就比如今天我要說(shuō)的一個(gè)問(wèn)題:異常的處理。寫程序的時(shí)候一般都會(huì)通過(guò)try...catch...finally對(duì)異常進(jìn)行處理,但是我們真的能在寫程序的時(shí)候處理掉所有可能發(fā)生的異常嗎? 以及發(fā)生異常的時(shí)候執(zhí)行什么邏輯,返回什么提示信息,跳轉(zhuǎn)到什么頁(yè)面,這些都是要考慮到的。

二、基于@ControllerAdvice(加強(qiáng)的控制器)的異常處理

@ControllerAdvice注解內(nèi)部使用@ExceptionHandler、@InitBinder、@ModelAttribute注解的方法應(yīng)用到所有的 @RequestMapping注解的方法。本例子中使用ExceptionHandler應(yīng)用到所有@RequestMapping注解的方法,處理發(fā)生的異常。

示例代碼:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;

import com.hjz.exception.ServiceException;
import com.hjz.exception.utils.ExceptionUtils;

@ResponseBody
public class ExceptionAdvice {
 private static final Logger LOGGER = LoggerFactory.getLogger(ExceptionAdvice.class);

 /**
  * 攔截web層異常,記錄異常日志,并返回友好信息到前端
  * 目前只攔截Exception,是否要攔截Error需再做考慮
  *
  * @param e 異常對(duì)象
  * @return 異常提示
  */
 @ExceptionHandler(Exception.class)
 public ResponseEntity handleException(Exception e) {
  //不需要再記錄ServiceException,因?yàn)樵趕ervice異常切面中已經(jīng)記錄過(guò)
  if (!(e instanceof ServiceException)) {
   LOGGER.error(ExceptionUtils.getExcTrace(e));
  }

  HttpHeaders headers = new HttpHeaders();
  headers.set("Content-type", "text/plain;charset=UTF-8");
  headers.add("icop-content-type", "exception");
  String message = StringUtils.isEmpty(e.getMessage()) ? "系統(tǒng)異常!!" : e.getMessage();
  return new ResponseEntity<>(message, headers, HttpStatus.OK);
 }
}

如果不起作用,請(qǐng)檢查 spring-mvc的配置文件,是否有ControllerAdvice的如下配置

 
   
   
  

三、基于AOP的異常處理

1.處理controller層的異常 WebExceptionAspect.java

import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import com.hjz.exception.ServiceException;
import com.hjz.exception.utils.ExceptionUtils;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * web異常切面
 * 默認(rèn)spring aop不會(huì)攔截controller層,使用該類需要在spring公共配置文件中注入改bean,
 * 另外需要配置
 */
@Aspect
public class WebExceptionAspect {
 private static final Logger LOGGER = LoggerFactory.getLogger(WebExceptionAspect.class);

 @Pointcut("@annotation(org.springframework.web.bind.annotation.RequestMapping)")
 private void webPointcut() {}

 /**
  * 攔截web層異常,記錄異常日志,并返回友好信息到前端
  * 目前只攔截Exception,是否要攔截Error需再做考慮
  *
  * @param e 異常對(duì)象
  */
 @AfterThrowing(pointcut = "webPointcut()", throwing = "e")
 public void handleThrowing(Exception e) {
  //不需要再記錄ServiceException,因?yàn)樵趕ervice異常切面中已經(jīng)記錄過(guò)
  if (!(e instanceof ServiceException)) {
   LOGGER.error(ExceptionUtils.getExcTrace(e));
  }

  String errorMsg = StringUtils.isEmpty(e.getMessage()) ? "系統(tǒng)異常" : e.getMessage();
  writeContent(errorMsg);
 }

 /**
  * 將內(nèi)容輸出到瀏覽器
  *
  * @param content 輸出內(nèi)容
  */
 private void writeContent(String content) {
  HttpServletResponse response = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getResponse();
  response.reset();
  response.setCharacterEncoding("UTF-8");
  response.setHeader("Content-Type", "text/plain;charset=UTF-8");
  response.setHeader("icop-content-type", "exception");
  PrintWriter writer = null;
  try {
   writer = response.getWriter();
  } catch (IOException e) {
   e.printStackTrace();
  }
  writer.print(content);
  writer.flush();
  writer.close();
 }
}

2.處理service層的異常ServiceExceptionAspect .java

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;

import com.hjz.exception.ServiceException;
import com.hjz.exception.utils.ExceptionUtils;

@Aspect
public class ServiceExceptionAspect {
 private static final Logger LOGGER = LoggerFactory.getLogger(ServiceExceptionAspect.class);

 /**
  * @within(org.springframework.stereotype.Service),攔截帶有 @Service 注解的類的所有方法
  * @annotation(org.springframework.web.bind.annotation.RequestMapping),攔截帶有@RquestMapping的注解方法
  */
 @Pointcut("@within(org.springframework.stereotype.Service) && execution(public * *(..))")
 private void servicePointcut() {}

 /**
  * 攔截service層異常,記錄異常日志,并設(shè)置對(duì)應(yīng)的異常信息
  * 目前只攔截Exception,是否要攔截Error需再做考慮
  *
  * @param e 異常對(duì)象
  */
 @AfterThrowing(pointcut = "servicePointcut()", throwing = "e")
 public void handle(JoinPoint point, Exception e) {
  LOGGER.error(ExceptionUtils.getExcTrace(e));

  String signature = point.getSignature().toString();
  String errorMsg = getMessage(signature) == null ? (StringUtils.isEmpty(e.getMessage()) ? "服務(wù)異常" : e.getMessage()) : getMessage(signature);
  throw new ServiceException(errorMsg, e);
 }

 /**
  * 獲取方法簽名對(duì)應(yīng)的提示消息
  *
  * @param signature 方法簽名
  * @return 提示消息
  */
 private String getMessage(String signature) {
  return null;
 }
}

3.使用方式,在spring的公共配置文件中加入如下配置:



或者 自定義一個(gè) 注冊(cè)類,ServiceExceptionAspect.java和WebExceptionAspect.java都加入@Component注解

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.EnableAspectJAutoProxy;

/**
 * 異常相關(guān)bean注冊(cè)類
 */
@Configuration
@EnableAspectJAutoProxy
@ComponentScan("com.hjz.exception.aspect")
public class ExceptionConfig {

}
@Aspect
@Component
public class WebExceptionAspect {
 .......... 
}


@Aspect
@Component
public class ServiceExceptionAspect {
 .........
}

四、疑惑

@within(org.springframework.stereotype.Service),攔截帶有 @Service 注解的類的所有方法

@annotation(org.springframework.web.bind.annotation.RequestMapping),攔截帶有@RquestMapping的注解方法

關(guān)于java利用spring注解實(shí)現(xiàn)處理異常AOP問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


文章題目:java利用spring注解實(shí)現(xiàn)處理異常AOP
網(wǎng)址分享:http://weahome.cn/article/ppoohs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部