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


Java Signature.getName方法代碼示例

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


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

示例1: args

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
@Around("set(* (@com.lib.logthisannotations.annotation.LogThisClassFields *) . *) && args(newVal) && target(t) ")
public void aroundSetField(ProceedingJoinPoint jp, Object t, Object newVal) throws Throwable{
    Logger logger = Logger.getInstance();
    if(logger != null) {
        Signature signature = jp.getSignature();
        String fieldName = signature.getName();
        Field field = t.getClass().getDeclaredField(fieldName);
        field.setAccessible(true);
        Object oldVal = field.get(t);
        LogThisClassFields annotation = t.getClass().getAnnotation(LogThisClassFields.class);
        LoggerLevel loggerLevel = annotation.logger();
        StringBuilder builder = Strings.getStringFieldBuilder(fieldName, String.valueOf(oldVal), String.valueOf(newVal));

        logger.getLoggerInstance().log(t.getClass().getName(), "ClassField " + builder.toString(), loggerLevel, annotation.write());
        jp.proceed();
    }
}
 
開發者ID:luispereira,項目名稱:LogThis,代碼行數:18,代碼來源:LogThisClassFieldAspect.java

示例2: exitMethod

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
private static void exitMethod(JoinPoint joinPoint, Object result, long lengthMillis) {
  if (!enabled) return;

  Signature signature = joinPoint.getSignature();

  Class<?> cls = signature.getDeclaringType();
  String methodName = signature.getName();
  boolean hasReturnType = signature instanceof MethodSignature
      && ((MethodSignature) signature).getReturnType() != void.class;

  StringBuilder builder = new StringBuilder("\u21E0 ")
      .append(methodName)
      .append(" [")
      .append(lengthMillis)
      .append("ms]");

  if (hasReturnType) {
    builder.append(" = ");
    builder.append(Strings.toString(result));
  }

  // TODO : use a real Logger
  System.out.println(asTag(cls) + " : " + builder.toString());
}
 
開發者ID:fpoyer,項目名稱:Hugo-Spring,代碼行數:25,代碼來源:Hugo.java

示例3: afterAnyMethodThrowingException

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
@AfterThrowing(pointcut = "anyMethodCall(joinPoint)", throwing = "exception")
public void afterAnyMethodThrowingException(JoinPoint joinPoint, Throwable exception) {
  
  if (log.isDebugEnabled()) {
    log.debug("aspect start: afterAnyMethodThrowingException");
  }
  
  Signature signature = joinPoint.getSignature();
  String className  = signature.getDeclaringTypeName();
  String methodName = signature.getName();
  String arguments = Arrays.toString(joinPoint.getArgs());
  
  StackTraceElement[] stackTrace = exception.getStackTrace();
  if (stackTrace.length == 0 || 
      !methodName.equals(stackTrace[0].getMethodName()) ||
      !className.equals(stackTrace[0].getClassName())) {
      return;
  }
  
  if (log.isDebugEnabled()) {
    log.debug("We have caught exception in method: "
        + methodName + " with arguments "
        + arguments + "\nand the full toString: " + "\nthe exception is: "
        + exception.toString());
  }
  
  ExceptionInfo exceptionInfo = 
      new ExceptionInfo()
      .setException(exception)
      .setName(exception.getClass().toString())
      .setClassName(className)
      .setFileName(stackTrace[0].getFileName())
      .setLineNumber(stackTrace[0].getLineNumber())
      .setMethodName(methodName)
      .setArguments(Arrays.asList(joinPoint.getArgs()));
  
  ExceptionEventPublisher exceptionEventPublisher = new ExceptionEventPublisher();
  exceptionEventPublisher.publishEvent(exceptionInfo);
}
 
開發者ID:sepulrator,項目名稱:java-exception-api,代碼行數:40,代碼來源:ThrowedExceptionAspectHandler.java

示例4: builderAtributosClasse

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
public static AtributosClasse builderAtributosClasse(JoinPoint joinPoint) {
	AtributosClasse atributosClasse = new AtributosClasse();
	Signature signature = joinPoint.getSignature();
	String methodName = signature.getName();
	String arguments = Arrays.toString(joinPoint.getArgs());
	atributosClasse.setMetodoNome(methodName);
	atributosClasse.setArgumentos(arguments);

	final MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
	Method method = methodSignature.getMethod();
	atributosClasse.setReturnType(method.getReturnType().getName());

	return atributosClasse;
}
 
開發者ID:tudoNoob,項目名稱:poseidon,代碼行數:15,代碼來源:AtributosClasse.java

示例5: stop

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
/**
 * Save invocation/execution time associated with the method to StatsD in the format: com.mypackage.myMethod
 */
@Override
public void stop(TimerContext context) {  
   Signature sig = context.getJoinPoint().getSignature();
   String className = sig.getDeclaringTypeName(); // package name: com.my.package
   String methodName = sig.getName(); // method name: myMethod
   String label = className+"."+methodName;
    
   statsdClient.recordExecutionTime(label, context.stop());
}
 
開發者ID:stevensouza,項目名稱:automon,代碼行數:13,代碼來源:StatsD.java

示例6: traceEntry

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
private void traceEntry(final Class<? extends Object> aThis, final Class<? extends Object> target, final Signature signature, final SourceLocation sourceLocation, final Object[] args) {
    if(aThis != null && target != null) {
        String message = aThis.getName() + " -> " + target.getName() + " : " + signature.getName() + "(" + Arrays.deepToString(args) + ")";
        messages.add(new TracingEvent(TraceType.ENTRY, aThis, target, signature, sourceLocation, args));
        System.out.println(message);
    }
}
 
開發者ID:jensnerche,項目名稱:TraceToPlantUml,代碼行數:8,代碼來源:TracingAspect.java

示例7: exitMethod

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
private static void exitMethod(JoinPoint joinPoint, Object result, long lengthMillis) {
  if (!enabled) return;

  if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR2) {
    Trace.endSection();
  }

  Signature signature = joinPoint.getSignature();

  Class<?> cls = signature.getDeclaringType();
  String methodName = signature.getName();
  boolean hasReturnType = signature instanceof MethodSignature
      && ((MethodSignature) signature).getReturnType() != void.class;

  StringBuilder builder = new StringBuilder("\u21E0 ")
      .append(methodName)
      .append(" [")
      .append(lengthMillis)
      .append("ms]");

  if (hasReturnType) {
    builder.append(" = ");
    builder.append(Strings.toString(result));
  }

  Log.v(asTag(cls), builder.toString());
}
 
開發者ID:JakeWharton,項目名稱:hugo,代碼行數:28,代碼來源:Hugo.java

示例8: buildLog

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
/**
 * 構建日誌參數
 * @param joinPoint
 * @return
 */
private SysUserLog buildLog(ProceedingJoinPoint joinPoint) throws Throwable {
	SysUserLog userLog = new SysUserLog();
	try{
		Object principal = SecurityUtils.getSubject().getPrincipal();
		if (principal != null) {
			userLog.setCreator(SecurityUtils.getSubject().getPrincipal().toString());
		}
		SysUser user = (SysUser) SecurityUtils.getSubject().getSession(true).getAttribute(SysUser.SYS_USER);
		if (user != null) {
			userLog.setUserId(user.getUserId());
			userLog.setUserName(user.getUserName());
		}
		userLog.setIp(SecurityUtils.getSubject().getSession(true).getHost());
	}catch (Exception e){
		//TODO No SecurityManager accessible to the calling code, either bound to the org.apache.shiro.util.ThreadContext or as a vm static singleton.  This is an invalid application configuration.
	}
	userLog.setCreateTime(new Date());

	//將日誌信息打印在控製台
	Signature signature = joinPoint.getSignature();
	String method=signature.getDeclaringTypeName() + " " + signature.getName();
	userLog.setMethod(method);

	//String parameter=StringUtils.join(joinPoint.getArgs(),",");
	StringBuilder builder=new StringBuilder();
	Object[] joinPointArgs = joinPoint.getArgs();
	for (Object arg:joinPointArgs){
		if(arg instanceof HttpServletRequest||arg instanceof HttpServletResponse){
			continue;
		}
		if(arg instanceof Serializable){
			builder.append(gson.toJson(arg)+",");
		}else{
			builder.append(arg+",");
		}
	}
	int lastIndexOf = builder.lastIndexOf(",");
	if(lastIndexOf>-1){
		builder.deleteCharAt(lastIndexOf);
	}
	userLog.setParameter(builder.toString());

	long start = System.currentTimeMillis();
	Object proceed = joinPoint.proceed();
	long end = System.currentTimeMillis();
	String result=gson.toJson(proceed);
	userLog.setResult(result);
	userLog.setProceed(proceed);

	String usetime=(end - start) + "ms";
	userLog.setUsetime(usetime);
	return userLog;
}
 
開發者ID:babymm,項目名稱:mumu,代碼行數:59,代碼來源:SysLogRecoderAspect.java

示例9: exitMethod

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
private void exitMethod(ProceedingJoinPoint joinPoint, Object result, long exeTime) {
    Signature signature = joinPoint.getSignature();
    Class<?> clz = signature.getDeclaringType();
    String methodName = signature.getName();

    boolean hasReturnType = signature instanceof MethodSignature && ((MethodSignature)signature).getReturnType() != void.class;

    StringBuilder builder = new StringBuilder("\[email protected] Exit---------------------------------\n");

    if (hasReturnType){
        builder.append("return = " + result + "\n");
    }

    builder.append(methodName).append("[execute time = " + exeTime + "ms]");

    builder.append("\[email protected] Exit end---------------------------------\n");
    Log.d(clz.getSimpleName(), builder.toString());

}
 
開發者ID:jiangkang,項目名稱:KTools,代碼行數:20,代碼來源:L.java

示例10: getServiceCallDescription

import org.aspectj.lang.Signature; //導入方法依賴的package包/類
private String getServiceCallDescription(ProceedingJoinPoint joinpoint) {
	Signature signature = joinpoint.getSignature();
	String type = signature.getDeclaringType().getSimpleName();
	String methodName = signature.getName();
	return type + "." + methodName;
}
 
開發者ID:williamgrosset,項目名稱:OSCAR-ConCert,代碼行數:7,代碼來源:WebServiceLoggingAdvice.java


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