Karaf 4.1 - 从Apache Aries代理到Cassandra实体注释的ClassCastException

时间:2016-10-06 00:10:07

标签: java cassandra osgi apache-karaf karaf

我在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

Debug

1 个答案:

答案 0 :(得分:0)

在java中,任何注释在运行时都表示为代理。所以你有时可以解决这个问题。

您可以尝试使用clazz.getAnnotation(Table.class).name代替。