本文整理匯總了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"
);
}
}
示例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);
}
}
示例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);
}
示例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() + "結束***************");
}
示例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();
}
}
示例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());
}
示例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);
}
示例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);
}
}
示例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);
}
示例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");
}
}
示例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");
}
}
示例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));
}
示例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());
}
}
示例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);
}
}
示例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"));
}
}