我在karaf 4.1.0-SNAPSHOT中使用datastax java-driver-mapping时遇到了一个大问题,在这种情况下我需要从cassandra实体获取注释@Table:
@Table(name = "clients")
public class Client implements Serializable {
@PartitionKey
@Column(name = "client_id")
private String clientId;
@Column(name = "client_secret")
private String clientSecret;
//getters and setters ...
}
当我尝试在持久性捆绑包中执行此操作时,此实体位于模型包中,我有一个服务包和一个持久性包:
@Override
public void save(Serializable obj, Class clazz) {
System.out.println(((Table)clazz.getAnnotations()[0]).name());
}
我在System.out.println:
行中收到此错误java.lang.ClassCastException: com.sun.proxy.$Proxy110 cannot be cast to com.datastax.driver.mapping.annotations.Table
at io.twim.cassandra.TwimCassandraImpl.save(TwimCassandraImpl.java:159) [216:twim-cassandra:1.0.0.SNAPSHOT]
at Proxyc0a03eb5_6454_4ea2_a12f_daddf586d502.save(Unknown Source) [?:?]
at io.twim.core.users.TwimServiceUserImpl.saveApplicationClient(TwimServiceUserImpl.java:50) [218:twim-core:1.0.0.SNAPSHOT]
at Proxy60a7b95f_6d2d_4487_bd18_dfd7c359a958.saveApplicationClient(Unknown Source) [?:?]
at io.twim.rest.register.ClientRegistrationImpl.init(ClientRegistrationImpl.java:69) [223:twim-rest:1.0.0.SNAPSHOT]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:?]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?]
at java.lang.reflect.Method.invoke(Method.java:497) ~[?:?]
at org.apache.aries.blueprint.utils.ReflectionUtils.invoke(ReflectionUtils.java:299) [12:org.apache.aries.blueprint.core:1.7.0]
我该怎么做才能解决这个问题?有人有任何想法吗?
EDITED
答案 0 :(得分:0)
在java中,任何注释在运行时都表示为代理。所以你有时可以解决这个问题。
您可以尝试使用clazz.getAnnotation(Table.class).name代替。