【问题标题】:java.lang.IllegalAccessError :MappingCassandraConverter Error when doing insert using Spring Cassandrajava.lang.IllegalAccessError :MappingCassandraConverter 使用 Spring Cassandra 进行插入时出错
【发布时间】:2016-03-24 05:32:00
【问题描述】:

我是 Spring 新手,所以请原谅我的基本问题。我正在使用基于 spring 的 cassandra 来执行一些 CRUD 操作。一个简单的插入似乎不起作用,想知道是否有人能指出我做错了什么。以下是我简单地插入时得到的错误

java.lang.IllegalAccessError: tried to access class org.springframework.data.mapping.model.BeanWrapper from class org.springframework.data.cassandra.convert.MappingCassandraConverter
at org.springframework.data.cassandra.convert.MappingCassandraConverter.writeInsertFromObject(MappingCassandraConverter.java:233) ~[spring-data-cassandra-1.2.2.RELEASE.jar:na]
at org.springframework.data.cassandra.convert.MappingCassandraConverter.write(MappingCassandraConverter.java:222) ~[spring-data-cassandra-1.2.2.RELEASE.jar:na]
at org.springframework.data.cassandra.core.CassandraTemplate.createInsertQuery(CassandraTemplate.java:841) ~[spring-data-cassandra-1.2.2.RELEASE.jar:na]
at org.springframework.data.cassandra.core.CassandraTemplate.doInsert(CassandraTemplate.java:640) ~[spring-data-cassandra-1.2.2.RELEASE.jar:na]
at org.springframework.data.cassandra.core.CassandraTemplate.insert(CassandraTemplate.java:238) ~[spring-data-cassandra-1.2.2.RELEASE.jar:na]
at org.springframework.data.cassandra.core.CassandraTemplate.insert(CassandraTemplate.java:233) ~[spring-data-cassandra-1.2.2.RELEASE.jar:na]

代码如下:

@Configuration
@PropertySource(value = { "classpath:cassandra.properties" })
@EnableCassandraRepositories
public class CassandraConfig {

    @Autowired
    private Environment environment;

    @Bean
    public CassandraOperations cassandraTemplate(Session someSession) throws Exception {
         return new CassandraTemplate(someSession);
    }

    @Bean
    public CassandraMappingContext mappingContext() {
        return new BasicCassandraMappingContext();
    }

    @Bean
    public CassandraConverter converter() {
        return new MappingCassandraConverter(mappingContext());
    }}

假设会话有效。这是实际执行写入的代码

@Component
public class SomeQueries {
@Autowired
CassandraOperations cassandraOps;

public void insertCart(Addresses addr){
    cassandraOps.insert(addr);
}
}

这是地址的对象:

    @Data
        @NoArgsConstructor
        @Table(value = "addresses")
        public class Addresses implements Serializable{

            @PrimaryKeyColumn(name = "account_id", ordinal = 0, type = PrimaryKeyType.PARTITIONED)
            private UUID accountId;

            @PrimaryKeyColumn(name = "address_id", ordinal = 1, type = PrimaryKeyType.PARTITIONED)
            private int addressId;

            @PrimaryKeyColumn(name = "is_primary", ordinal = 2, type = PrimaryKeyType.PARTITIONED)
            private boolean isPrimary;

            @Column("name") private String name;
            @Column("creation_date") private Date creationTimestamp;
            @Column("last_modified_date") private Date lastModifiedTimestamp;   

            @Override
            public int hashCode() {
                final int prime = 31;
                int result = 1;
                result = prime * result + ((accountId == null) ? 0 : accountId.hashCode());
                result = prime * result + addressId;
                result = prime * result + ((creationTimestamp == null) ? 0 : creationTimestamp.hashCode());
                result = prime * result + (isPrimary ? 1231 : 1237);
                result = prime * result + ((lastModifiedTimestamp == null) ? 0 : lastModifiedTimestamp.hashCode());
                result = prime * result + ((name == null) ? 0 : name.hashCode());
                return result;
            }

            @Override
            public boolean equals(Object obj) {
                if (this == obj)
                    return true;
                if (obj == null)
                    return false;
                if (getClass() != obj.getClass())
                    return false;
                DeliveryAddresses other = (DeliveryAddresses) obj;
                if (accountId == null) {
                    if (other.accountId != null)
                        return false;
                } else if (!accountId.equals(other.accountId))
                    return false;
else if (!address.equals(other.address))
                    return false;
                if (addressId != other.addressId)
                    return false;
                if (creationTimestamp == null) {
                    if (other.creationTimestamp != null)
                        return false;
                } else if (!creationTimestamp.equals(other.creationTimestamp))
                    return false;
                if (isPrimary != other.isPrimary)
                    return false;
                if (lastModifiedTimestamp == null) {
                    if (other.lastModifiedTimestamp != null)
                        return false;
                } else if (!lastModifiedTimestamp.equals(other.lastModifiedTimestamp))
                    return false;
                if (name == null) {
                    if (other.name != null)
                        return false;
                } else if (!name.equals(other.name))
                    return false;
                return true;
            }
            }

我有什么需要初始化的吗?

【问题讨论】:

  • 你能添加你正在使用的 Spring 和 Spring Data Cassandra 的版本吗?我在 Spring Data Cassandra 的最新代码中看到他们从 MappingCassandraConverter (github.com/spring-projects/spring-data-cassandra/blob/master/…) 中删除了 BeanWrapper,因此如果您可以选择升级到最新版本 (1.3.0)?
  • 谢谢...我更新了版本,似乎正在解决问题。
  • 没问题,我为您的问题添加了答案以供将来参考。如果它解决了您的问题,您可以将其标记为已接受,并可能添加您使用的 Spring Data CAssandra 版本,以便偶然发现相同问题的人可以与版本相关

标签: datastax-enterprise datastax-java-driver spring-data-cassandra


【解决方案1】:

BeanWrapper 在 Spring Data Cassandra 1.2.0 中已弃用。版本并在代码和 Github 上为MappingCassandraConverter BeanWrapper 的最新代码中使用 TODO 注释标记为删除它已被删除。

您可以将 Spring Data Cassandra 升级到 1.3.0 版本,BeanWrapper 异常将消失。

【讨论】:

    猜你喜欢
    • 2021-08-27
    • 2011-01-30
    • 2020-08-10
    • 2016-02-06
    • 2017-02-12
    • 2016-09-01
    • 2016-03-16
    • 1970-01-01
    相关资源
    最近更新 更多