struts2 ActionInvocation 获取不到注解的值,麻烦各位帮忙看下?

发布于 2022-09-06 20:29:51 字数 2005 浏览 21 评论 0

注解

/**
 * 系统日志注解
 *
 * @author linyuting
 * @since 2018-3-13
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface SysLogAnnotation {

    String value() default "";
}

拦截器

    @Override
    public String intercept(ActionInvocation ai)
        throws Exception
    {
        try
        {
            String methodName = ai.getProxy().getMethod();
            Method currentMethod = ai.getAction().getClass().getMethod(methodName, null);
            if (currentMethod.isAnnotationPresent(SysLogAnnotation.class))
            {
                SysLogAnnotation sysLogAnnotation = currentMethod.getAnnotation(SysLogAnnotation.class);
                if (sysLogAnnotation != null)
                {
                    StringUtil.log(sysLogAnnotation.value());
                }
            }

            StringUtil.log(StringUtil.log(new Date()));
            SysLogin user = (SysLogin)SecurityUtils.getSubject().getPrincipal();
            if (user != null)
            {
                StringUtil.log("操作人:" + user.getName());
            }
            else
            {
                StringUtil.log("操作人:系统未获取");
            }
            StringUtil.log("类名:" + ai.getAction() + " ");
            StringUtil.log("方法名:" + ai.getInvocationContext().getName() + " ");
            Map<String, Object> map = ai.getInvocationContext().getParameters();
            Set<String> keys = map.keySet();
            StringUtil.log("参数:");
            for (String key : keys)
            {
                StringUtil.log(key + "=" + ((Object[])map.get(key))[0] + "#");
            }
            StringUtil.log(" ");
            StringUtil.log("执行结果:" + ai.getResultCode() + " ");
            // SysLog syslog = new SysLog();
            // sysLogService.insert(syslog);
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
        return ai.invoke();
    }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

过潦 2022-09-13 20:29:51

这个是因为spring的动态代理,把class去掉动态代理那块字符串,再转成类就能获取到注解了.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文