Mam kilka metod, które rzuca wyjątek, i chcę użyć AspectJ wokół doradzić, aby obliczyć czas wykonania i jeśli wyjątek jest wyrzucony i zalogować się do dziennika błędów i kontynuować przepływ przez ponowne rzucenie wyjątku.Jak ponownie rzucić wyjątek w AspectJ wokół doradzić
Próbowałem osiągnąć to przez obserwowanie, ale zaćmienie mówi "Nieobsługiwany typ wyjątku".
Code-przeciwko któremu AspectJ jest używane: -
public interface Iface {
public void reload() throws TException;
public TUser getUserFromUserId(int userId, String serverId) throws ResumeNotFoundException, TException;
public TUser getUserFromUsername(String username, String serverId) throws ResumeNotFoundException, TException;
public TResume getPartialActiveProfileFromUserId(int userId, int sectionsBitField, String serverId) throws ResumeNotFoundException, UserNotFoundException;
public TResume getPartialActiveProfileFromUsername(String username, int sectionsBitField, String serverId) throws ResumeNotFoundException, UserNotFoundException, TException;
}
Kod AspectJ: -
public aspect AspectServerLog {
public static final Logger ERR_LOG = LoggerFactory.getLogger("error");
Object around() : call (* com.abc.Iface.* (..)) {
Object ret;
Throwable ex = null;
StopWatch watch = new Slf4JStopWatch();
try {
ret = proceed();
}catch (UserNotFoundException e) {
ex = e ;
throw e ;
} catch (ResumeNotFoundException e) {
ex = e ;
throw e ;
} catch (Throwable e) {
ex = e ;
throw new RuntimeException(e);
}finally{
watch.stop(thisJoinPoint.toShortString());
if(ex!=null){
StringBuilder mesg = new StringBuilder("Exception in ");
mesg.append(thisJoinPoint.toShortString()).append('(');
for(Object o : thisJoinPoint.getArgs()) {
mesg.append(o).append(',');
}
mesg.append(')');
ERR_LOG.error(mesg.toString(), ex);
numEx++;
}
}
return ret;
}
}
Proszę o pomoc, dlaczego ten AspectJ nie działa.
dzięki, to jest świetne proste rozwiązanie. –