當前位置: 首頁>>代碼示例>>Java>>正文


Java AfterThrowing類代碼示例

本文整理匯總了Java中org.aspectj.lang.annotation.AfterThrowing的典型用法代碼示例。如果您正苦於以下問題:Java AfterThrowing類的具體用法?Java AfterThrowing怎麽用?Java AfterThrowing使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


AfterThrowing類屬於org.aspectj.lang.annotation包,在下文中一共展示了AfterThrowing類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: logAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
/**
 * Advice that logs methods throwing exceptions.
 */
@AfterThrowing(pointcut = "loggingPointcut()", throwing = "e")
public void logAfterThrowing(JoinPoint joinPoint, Throwable e) {
    if (env.acceptsProfiles("dev")) {
        log.error("Exception in {}.{}() with cause = \'{}\' and exception = \'{}\'",
            joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(),
            e.getCause() != null ? e.getCause() : "NULL", e.getMessage(),
            e
        );

    } else {
        log.error("Exception in {}.{}() with cause = {}",
            joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(),
            e.getCause() != null ? e.getCause() : "NULL"
        );
    }
}
 
開發者ID:Cinderpup,項目名稱:RoboInsta,代碼行數:22,代碼來源:LoggingAspect.java

示例2: execution

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(pointcut = "execution(* cn.org.once.cstack.service.ModuleService.remove(..)) " +
    "|| execution(* cn.org.once.cstack.service.ModuleService.initModule(..))",
    throwing = "e")
public void afterThrowingModule(StaticPart staticPart,
                                Exception e)
    throws ServiceException {
    User user = this.getAuthentificatedUser();
    Message message = null;
    logger.debug("CALLED CLASS : " + staticPart.getSignature().getName());
    switch (staticPart.getSignature().getName().toUpperCase()) {
        case initModule:
            message = MessageUtils.writeAfterThrowingModuleMessage(e, user,
                initModule);
            break;
        case deleteType:
            message = MessageUtils.writeAfterThrowingModuleMessage(e, user,
                deleteType);
            break;
    }
    if (message != null) {
        messageService.create(message);
    }
}
 
開發者ID:oncecloud,項目名稱:devops-cstack,代碼行數:24,代碼來源:ModuleAspect.java

示例3: afterThrowingLoggable

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(value = "execution(@org.smartlog.aop.Loggable * *(..))", throwing = "t")
public void afterThrowingLoggable(final JoinPoint joinPoint, final Throwable t) throws Throwable {
    final LogContext ctx = SmartLog.throwable(t);

    if (ctx.level() == null) {
        // use ERROR level by default when got uncaught exception
        ctx.level(LogLevel.ERROR);
    }

    final Object result = ctx.result();
    if (result == null) {
        ctx.result(t.toString());
    } else {
        ctx.result(result.toString() + "; " + t.toString());
    }

    finish(joinPoint, ctx);
}
 
開發者ID:ivnik,項目名稱:smartlog,代碼行數:19,代碼來源:LogAspect.java

示例4: doAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(throwing = "ex", pointcut = "webLog()")
public void doAfterThrowing(Throwable ex) {
    //有異常
    WebOosLog commLogger = commLoggerThreadLocal.get();
    if (ex instanceof BusinessException) {
        commLogger.setActionResCode(ResponseStatus.BUSINESS_FAILED);
    } else if (ex instanceof ValidateException) {
        commLogger.setActionResCode(ResponseStatus.VALIDATE_ERR);
    } else if (ex instanceof LoginTimeoutException) {
        commLogger.setActionResCode(ResponseStatus.LOGIN_TIME_OUT);
    } else if (ex instanceof NoPrivilegeException) {
        commLogger.setActionResCode(ResponseStatus.NO_PRIVILEGE);
    } else {
        commLogger.setActionResCode(ResponseStatus.SYSTEM_ERR);
    }
    commLogger.setReqEndTime(new Date());
    commLogger.setReqDealTime((int) (commLogger.getReqEndTime().getTime() - commLogger.getReqStartTime().getTime()));
    commLogger.setIsUndefinedException(true);
    commLogger.setExcepStackInfo(ExceptionUtil.parseException(ex));

    loggerRecordService.doRecord(commLogger);

    logger.debug("EXCEPTION : " + ExceptionUtil.parseException(ex));
    logger.debug("SPEND TIME : " + commLogger.getReqDealTime() + "ms");
    logger.debug("***************請求" + commLogger.getActionDesc() + "結束***************");
}
 
開發者ID:DomKing,項目名稱:springbootWeb,代碼行數:27,代碼來源:WebLogAspect.java

示例5: doException

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(pointcut = "controllerAspect()", throwing = "exception")
    public void doException(JoinPoint joinPoint, Exception exception) {
    	HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
		// 讀取session中的用戶
//		User user = SessionUtils.getUserFromSession(request);
		
//		if(null == user){
//			logger.info("未登錄日誌不記錄");
//			return;
//		}
		
		try {
			Object[] args = getLogMethodDescription(joinPoint);

			// *========數據庫日誌=========*//
//			logService.saveLog(user.getId(), user.getAccount(), LogType.EXCEPTION_LOG,
//					IpUtils.getIpAddr(request), args[0].toString() + "-->" + exception.getMessage(),
//					user.getManufacturerId(), reqDescription(request));

		} catch (Exception e) {
			// 記錄本地異常日誌
			logger.error(e);
			e.printStackTrace();
		}  
    }
 
開發者ID:javahongxi,項目名稱:whatsmars,代碼行數:26,代碼來源:SystemLogAspect.java

示例6: LogToDB

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(throwing = "ex", pointcut = "execution(* com.github.izhangzhihao.SSMSeedProject.*.*.*(..)))")
public void LogToDB(JoinPoint joinPoint, Throwable ex) {
    //出錯行
    int lineNumber = ex.getStackTrace()[0].getLineNumber();
    //方法簽名
    Signature signature = joinPoint.getSignature();
    //參數
    Object[] args = joinPoint.getArgs();
    //拚接參數
    StringBuilder argString = new StringBuilder();
    if (args.length > 0)
        for (Object arg : args)
            argString.append(arg);
    ex.printStackTrace();
    log.error("方法" + signature, "參數" + argString, "錯誤行:" + lineNumber, "時間" + new Date(), "異常內容" + ex.toString());
}
 
開發者ID:izhangzhihao,項目名稱:SSMSeedProject,代碼行數:17,代碼來源:LogAspect.java

示例7: afterThrowingAdvice

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
/**
	 * After throwing advice.
	 *
	 * @param joinPoint the join point
	 * @param error the error
	 */
	@AfterThrowing(pointcut = "selectAll()", throwing = "error")
	public void afterThrowingAdvice(JoinPoint joinPoint, Throwable error) {
		if (isAlreadySysPointCut(error)) {
			return;
		}
		setAlreadySysPointCut(error);
		if (error instanceof TestDataException) {
			ITestResult itr = Reporter.getCurrentTestResult();
			itr.setThrowable(error);
		}
//		String[] fullST = Utils.stackTrace(error, false);
//		LogbackWriter.writeSysError(joinPoint.getTarget().toString()+ error.hashCode()  + fullST[1] );
		Class<?> cls = joinPoint.getTarget().getClass();
		if (null == cls) throw GlobalUtils.createInternalError("jvm");
		LogbackWriter.writeSysError(cls,  error);
		
	}
 
開發者ID:bigtester,項目名稱:automation-test-engine,代碼行數:24,代碼來源:SystemLogger.java

示例8: ExceptionLog

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
/**
 * 出現異常自動記錄日誌
 * @param ex 異常
 */
@AfterThrowing(pointcut="methods()",
	    throwing="ex")
public void ExceptionLog(Exception ex) {
	LoginInfo loginUser = UserContextHolder.getUser();
	//保證用戶已經登陸後並通過菜單訪問功能時才記錄操作時間
	if (loginUser != null ) {
		Log log = new Log();
		log.setDf("0");
		log.setIp(loginUser.getIp());
		log.setPermission(loginUser.getPermission());
		log.setTs(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
		log.setType("APP_LOG001");
		log.setUsername(loginUser.getUserName());
		logManager.save(log);
	}
}
 
開發者ID:545473750,項目名稱:zswxsqxt,代碼行數:21,代碼來源:AfterThrowingUtil.java

示例9: auditAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(
        pointcut = "execution(* (@javax.jws.WebService *).*(..))",
        throwing = "throwable")
public void auditAfterThrowing(JoinPoint joinPoint, Throwable throwable) throws Throwable {
  String id = getId();
  Class targetClass = joinPoint.getTarget().getClass();
  String methodName = joinPoint.getSignature().getName();
  Object[] args = joinPoint.getArgs();

  LOG.info("[" + id + "] After exception: " + targetClass.getName() + "." + methodName + " with " + args.length + " params");

  AuditEntity ae = AuditEntity.getInstance(
          new Timestamp(new Date().getTime()).toString(),
          methodName,
          objectsToString(args),
          throwable != null ? throwable.toString() : null,
          STATE_EXCEPTION
  );

  LOG.info("[" + id + "] Exception: " + ae);
}
 
開發者ID:stockholmuniversity,項目名稱:cxf-server,代碼行數:22,代碼來源:AuditAspect.java

示例10: springBeanPointcut

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
/**
 * Advice that logs methods throwing exceptions.
 *
 * @param joinPoint join point for advice
 * @param e exception
 */
@AfterThrowing(pointcut = "applicationPackagePointcut() && springBeanPointcut()", throwing = "e")
public void logAfterThrowing(JoinPoint joinPoint, Throwable e) {
    if (env.acceptsProfiles(JHipsterConstants.SPRING_PROFILE_DEVELOPMENT)) {
        log.error("Exception in {}.{}() with cause = \'{}\' and exception = \'{}\'", joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(), e.getCause() != null? e.getCause() : "NULL", e.getMessage(), e);

    } else {
        log.error("Exception in {}.{}() with cause = {}", joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(), e.getCause() != null? e.getCause() : "NULL");
    }
}
 
開發者ID:oktadeveloper,項目名稱:jhipster-microservices-example,代碼行數:18,代碼來源:LoggingAspect.java

示例11: logAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
/**
 * Advice that logs methods throwing exceptions.
 *
 * @param joinPoint join point for advice
 * @param e exception
 */
@AfterThrowing(pointcut = "loggingPointcut()", throwing = "e")
public void logAfterThrowing(JoinPoint joinPoint, Throwable e) {
    if (env.acceptsProfiles(JHipsterConstants.SPRING_PROFILE_DEVELOPMENT)) {
        log.error("Exception in {}.{}() with cause = \'{}\' and exception = \'{}\'", joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(), e.getCause() != null? e.getCause() : "NULL", e.getMessage(), e);

    } else {
        log.error("Exception in {}.{}() with cause = {}", joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(), e.getCause() != null? e.getCause() : "NULL");
    }
}
 
開發者ID:oktadeveloper,項目名稱:jhipster-microservices-example,代碼行數:18,代碼來源:LoggingAspect.java

示例12: doAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
/**
 * @param joinPoint
 * @param e
 */
@AfterThrowing(value = "doAfterThrowing()", throwing = "e")
public void doAfterThrowing(JoinPoint joinPoint, Throwable e) {
    MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
    Method method = methodSignature.getMethod();

    Map<String, Object> map = new HashMap<String, Object>();
    map.put("className", joinPoint.getTarget().getClass().getName());
    map.put("methodName", method.getName());
    map.put("args", JSONUtils.toJSONString(joinPoint.getArgs().toString()));
    map.put("errorMsg", e.getMessage());
    logger.error(JSONUtils.toJSONString(map));
}
 
開發者ID:melonlee,項目名稱:LazyREST,代碼行數:17,代碼來源:ExceptionLogAspect.java

示例13: logAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(pointcut = "loggingPointcut()", throwing = "e")
public void logAfterThrowing(JoinPoint joinPoint, Throwable e) {
    if (env.acceptsProfiles(Constants.SPRING_PROFILE_DEVELOPMENT)) {
        log.error("Exception in {}.{}() with cause = {}", joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(), e.getCause(), e);
    } else {
        log.error("Exception in {}.{}() with cause = {}", joinPoint.getSignature().getDeclaringTypeName(),
            joinPoint.getSignature().getName(), e.getCause());
    }
}
 
開發者ID:GastonMauroDiaz,項目名稱:buenojo,代碼行數:11,代碼來源:LoggingAspect.java

示例14: afterThrowingServer

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(pointcut = "execution(* cn.org.once.cstack.ServerService.updateType(..))", throwing = "e")
public void afterThrowingServer(StaticPart staticPart, Exception e) throws ServiceException {
	User user = this.getAuthentificatedUser();
	Message message = null;
	logger.debug("CALLED CLASS : " + staticPart.getSignature().getName());
	switch (staticPart.getSignature().getName().toUpperCase()) {
	case updateType:
		message = MessageUtils.writeAfterThrowingModuleMessage(e, user, updateType);
		break;
	}
	if (message != null) {
		messageService.create(message);
	}
}
 
開發者ID:oncecloud,項目名稱:devops-cstack,代碼行數:15,代碼來源:ServerAspect.java

示例15: logAfterThrowing

import org.aspectj.lang.annotation.AfterThrowing; //導入依賴的package包/類
@AfterThrowing(pointcut = "execution(* cn.org.once.cstack.service.*.*(..))",
        throwing= "error")
public void logAfterThrowing(Throwable error) {
    if(error.getMessage() != null && error.getMessage()
            .contains("org.hibernate.exception.JDBCConnectionException: could not extract ResultSet")) {
        publisher.publishEvent(new DatabaseConnectionFailEvent("Database connection has been lost"));
    }
}
 
開發者ID:oncecloud,項目名稱:devops-cstack,代碼行數:9,代碼來源:ErrorHandlerAspect.java


注:本文中的org.aspectj.lang.annotation.AfterThrowing類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。