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


Java Signature.toShortString方法代碼示例

本文整理匯總了Java中org.aspectj.lang.Signature.toShortString方法的典型用法代碼示例。如果您正苦於以下問題:Java Signature.toShortString方法的具體用法?Java Signature.toShortString怎麽用?Java Signature.toShortString使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.aspectj.lang.Signature的用法示例。


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

示例1: monitorElapsedTime

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
/**
 * Monitor the elapsed time of method on controller layer, in
 * order to detect performance problems as soon as possible.
 * If elapsed time > 1 s, log it as an error. Otherwise, log it
 * as an info.
 */
@Around("controllerLayer()")
public Object monitorElapsedTime(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
    // Timing the method in controller layer
    StopWatch stopWatch = new StopWatch();
    stopWatch.start();
    Object result = proceedingJoinPoint.proceed();
    stopWatch.stop();

    // Log the elapsed time
    double elapsedTime = stopWatch.getTime() / 1000.0;
    Signature signature = proceedingJoinPoint.getSignature();
    String infoString = "[" + signature.toShortString() + "][Elapsed time: " + elapsedTime + " s]";
    if (elapsedTime > 1) {
        log.error(infoString + "[Note that it's time consuming!]");
    } else {
        log.info(infoString);
    }

    // Return the result
    return result;
}
 
開發者ID:ustcwudi,項目名稱:springboot-seed,代碼行數:28,代碼來源:PerformanceMonitor.java

示例2: entering

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
/**
 * @param joinPoint Counts the invocation for the given joinPoint
 */
public static synchronized void entering(JoinPoint joinPoint) {
	final Signature signature = joinPoint.getSignature();
	final String methodName = signature.toShortString();
	Integer invocedTimes = invoctions.get(methodName);
	
	if(invocedTimes == null) {
		invoctions.put(methodName, 1);
	} else {
		int i = invocedTimes.intValue();
		invoctions.put(methodName, ++i);
	}
}
 
開發者ID:tlaplus,項目名稱:tlaplus,代碼行數:16,代碼來源:RMIMethodMonitor.java

示例3: log

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
/**
 * Advice that will be executed around each join point that has been selected by the
 * 'loggingPointcut()' pointcut.  This advice will log the entry, exit of the joint put
 * including the available contextual information.
 * @param call exposes the proceed(..) method in order to support around advice in @AJ aspects
 * @return the method return value
 * @throws Throwable any throwable thrown by the execution
 */
@Pointcut("be.gerard.common.aop.PointCutLibrary.springServiceOperation()")
public Object log(final ProceedingJoinPoint call) throws Throwable {
    // Get the logger that handles the target instance of the method execution.
    Signature signature = call.getSignature();
    Logger logger = LogManager.getLogger(signature.getDeclaringType());

    // This aspect is only valid for method calls
    if (!(signature instanceof MethodSignature)) {
        throw new IllegalArgumentException("call not valid [method call expected]");
    }
    MethodSignature methodSignature = (MethodSignature) signature;

    // Compute the method information
    String methodName = signature.toShortString();
    String targetName = signature.getDeclaringTypeName();
    Type returnType = methodSignature.getReturnType();

    // AspectJ compiler has to be used to retrieve the parameter names
    //String[] pp = methodSignature.getParameterNames();

    // Compute the method parameters and trace the method entry
    if (logger.isInfoEnabled()) {
        logger.info(signature.toLongString());
        logger.info(String.format("Invoke method [%s] on service [%s]", methodName, targetName));
        Object[] parameterValues = call.getArgs();
        String[] parameterNames = new String[parameterValues.length];
        if ((methodSignature.getParameterNames() != null) && methodSignature.getParameterNames().length == parameterNames.length) {
            parameterNames = methodSignature.getParameterNames();
        }

        for (int i = 0; i < parameterValues.length; i++) {
            String parameterName = (parameterNames[i] == null ? String.valueOf(i) : parameterNames[i]);
            String parameterValue;
            if ((parameterValues[i] instanceof byte[]) && (parameterValues[i] != null)) {
                parameterValue = String.format("byte array length [%s]", ((byte[]) parameterValues[i]).length);
            } else {
                parameterValue = String.valueOf(parameterValues[i]);
            }
            logger.info(String.format("|---parameter [%s] = [%s]", parameterName, parameterValue));
        }
    }

    // Prepare a StopWath for computing the method statistic
    final StopWatch stopWatch = new StopWatch();
    stopWatch.start();
    String methodStatus = "SUCCESSFULLY";
    Object methodResult = null;
    try {
        // Proceed with the next advice or target method invocation
        methodResult = call.proceed();
        return methodResult;
    } catch (Exception throwable) {
        logger.info(String.format("Method [%s] raised the following exception :\n%s.", methodName, String.valueOf(throwable)));
        methodStatus = "UNSUCCESSFULLY";
        throw throwable;
    } finally {
        stopWatch.stop();
        final long millis = stopWatch.getTotalTimeMillis();

        if (logger.isInfoEnabled()) {
            if (returnType != null) {
                logger.info(String.format("|---parameter [return]= [%s]", String.valueOf(methodResult)));
            }
            logger.info(String.format("Method [%s] on service [%s] %s invoked in %s milliseconds.", methodName, targetName, methodStatus, millis));
        }
    }
}
 
開發者ID:bartgerard,項目名稱:ubrew_v0.1,代碼行數:76,代碼來源:LoggingAdvice.java

示例4: handleException

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
@AfterThrowing(pointcut = "be.gerard.common.aop.PointCutLibrary.springServiceOperation()", throwing = "exception")
public void handleException(final JoinPoint call, final Throwable exception) throws Throwable {
    if (exception instanceof BusinessException) {
        throw exception;
    }

    // Get the logger that handles the target instance of the method execution.
    Signature signature = call.getSignature();
    Logger logger = LogManager.getLogger(signature.getDeclaringType());

    MethodSignature methodSignature = (MethodSignature) signature;
    // Compute the method information
    String methodName = signature.toShortString();
    String targetName = signature.getDeclaringTypeName();
    Type returnType = methodSignature.getReturnType();

    // Compute the method parameters and prepare the exception context
    Map<String, String> exceptionContext = new LinkedHashMap<>();
    exceptionContext.put("request", call.getSignature().toLongString());
    exceptionContext.put("service name", targetName);
    exceptionContext.put("method name", methodName);
    
    if (returnType != null) {
        exceptionContext.put("return parameter", String.valueOf(returnType.getClass().getCanonicalName()));
    }

    // AspectJ compiler has to be used to retrieve the parameter names
    Object[] parameterValues = call.getArgs();
    String[] parameterNames = new String[parameterValues.length];
    
    if ((methodSignature.getParameterNames() != null) && methodSignature.getParameterNames().length == parameterNames.length) {
        parameterNames = methodSignature.getParameterNames();
    }
    
    for (int i = 0; i < parameterValues.length; i++) {
        String parameterName = (parameterNames[i] == null ? String.valueOf(i) : parameterNames[i]);
        exceptionContext.put(String.format("method parameter [%s]", parameterName), String.valueOf(parameterValues[i]));
    }

    // Prepare the contextual exception to be logged.
    String exceptionText = "An unexpected error was encountered while processing the service request.";
    ContextualException contextualException = new ContextualException(exceptionText, exception, exceptionContext);
    // Log the exception
    logger.error(contextualException.toString());
    // Throw the technical exception with the facadeException id.
    throw new TechnicalException(exceptionText, technicalError, String.format("#%s", contextualException.getId()));
}
 
開發者ID:bartgerard,項目名稱:ubrew_v0.1,代碼行數:48,代碼來源:ServiceExceptionAdvice.java


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