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