1

这是我在这里的第一篇文章,祝大家有愉快的一天:)

我创建了一个名为“验证”的注释

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Validate {
    Class<? extends MethodInterceptor>[] value();
}

然后在需要拦截的方法之前装饰它。

@Validate({OneInterceptor.class, TwoInterceptor.class})
public void doPost(HttpServletRequest req, HttpServletResponse resp) {
    //Do something
}


OneInterceptor implements MethodInterceptor {.....}  TwoInterceptor implements MethodInterceptor{....}

有没有可能通过使用 Guice 来绑定这样的拦截器?我只想让 Guice 在运行时动态绑定这些拦截器。谢谢大家!

4

2 回答 2

3

正如 mlk 所指出的,您可以编写一个 MethodInterceptor 来执行此操作,尽管没有理由提到所提到的验证器也必须是 MethodInterceptor ——事实上,这样可能会更容易,因为您不必担心proceed().

如果此代码无法编译,请原谅我,但它应该为您指明正确的方向:

public interface RequestValidator {
  void validate(HttpServletRequest req) throws ValidationError;
}

public class ValidationModule extends AbstractModule {
  @Override public void configure() {
    bindInterceptor(Matchers.any(), Matchers.annotatedWith(Validate.class), 
        new ValidateInterceptor());
  }
}

public class ValidateInterceptor implements MethodInterceptor {
  @Override public Object invoke(MethodInvocation invocation) throws Throwable {
    Method method = invocation.getMethod();
    Validate validate = method.getAnnotation(Validate.class);
    if (validate == null) {
      throw new IllegalStateException(
          "ValidateInterceptor installed on non-@Validate method");
    }
    for (Class<? extends RequestValidator> validatorClass : validate.value()) {
      RequestValidator validator = validatorClass.newInstance();
      validator.validate((HttpServletRequest) invocation.getArguments()[0]);
    }
    return invocation.proceed();
  }
}
于 2013-01-09T22:29:48.173 回答
0

你为什么要这样做?为什么不创建两个注释?

我不相信你可以直接做,但你可以写一个在方法注释MethodInterceptor中执行s 的方法。MethodInterceptor但是,为什么?

于 2013-01-09T12:35:08.333 回答