代理 @RabbitListener
和泛型
如果你的服务旨在被代理(例如,在 @Transactional
的情况下),当接口具有泛型参数时,你应该记住一些注意事项。
考虑以下示例:
interface TxService<P> {
String handle(P payload, String header);
}
static class TxServiceImpl implements TxService<Foo> {
@Override
@RabbitListener(...)
public String handle(Thing thing, String rk) {
...
}
}
对于一个泛型接口和一个特定实现,你被迫切换到 CGLIB 目标类代理,因为接口 handle
方法的实际实现是一个桥接方法。
在事务管理的情况下,CGLIB 的使用通过注解选项进行配置:@EnableTransactionManagement(proxyTargetClass = true)
。
在这种情况下,所有注解都必须在实现的 target 方法上声明,如以下示例所示:
static class TxServiceImpl implements TxService<Foo> {
@Override
@Transactional
@RabbitListener(...)
public String handle(@Payload Foo foo, @Header("amqp_receivedRoutingKey") String rk) {
...
}
}