gpt4 book ai didi

java - Spring Data REST 存储库中的枚举翻译

转载 作者:行者123 更新时间:2023-11-30 06:36:40 26 4
gpt4 key购买 nike

我正在使用 Spring Boot 1.5.4、Spring Data REST、HATEOAS。我公开了要从 Angular 客户端使用的 REST 端点。

我正在使用spring.data.rest.enable-enum-translation=true转换枚举。它在 GET 中都运行良好。和POST从存储库中的 Spring Data REST 公开的请求。

我在存储库中添加了一个自定义方法:

@Transactional(readOnly = true)
@PreAuthorize("isAuthenticated()")
public interface TransitCertificateRepository extends PagingAndSortingRepository<TransitCertificate, Long> {

@Query("SELECT t FROM TransitCertificate t WHERE :states IS NULL OR status IN (:states) ")
public Page<TransitCertificate> findAllByParameters(
@Param("states") @RequestParam(value = "states", required = false) List<TransitCertificateStatus> states, Pageable pageable);

这是枚举:

    public enum TransitCertificateStatus {
PENDING, USED, CANCELED, ARCHIVED
}

这是模型的相关部分:

@Entity
@EntityListeners(TransitCertificateListener.class)
public class TransitCertificate extends AbstractEntity {
private static final long serialVersionUID = 5978999252424024545L;

@NotNull(message = "The status cannot be empty")
@Column(nullable = false)
@Enumerated(EnumType.STRING)
private TransitCertificateStatus status = TransitCertificateStatus.PENDING;

rest-messages.properties我对枚举的翻译如下:

server.model.enums.TransitCertificateStatus.PENDING = Pending
server.model.enums.TransitCertificateStatus.USED = Used

当客户端尝试调用我的方法时findAllByParameters并发送一个 String 数组(翻译服务器如何发回),服务器上的转换失败。例如,我不明白为什么转换在 save() 方法中有效,但在我的方法中无效。此外,如果客户端向我发送 2 个状态,Spring 将返回此错误:

Parameter value element [USED] did not match expected type [server.model.enums.TransitCertificateStatus (n/a)]; nested exception is java.lang.IllegalArgumentException: Parameter value element [USED] did not match expected type [server.model.enums.TransitCertificateStatus (n/a)]

所以我想我有两个问题:

  1. 出于某种原因,Spring 无法转换 String[]List<TransitCertificateStatus>即使该值正是 TransitCertificateStatus 中定义的值(PENDING、USED、CANCELED、ARCHIVED)
  2. 当该值是 rest-messages.properties 中定义的值之一时,Spring 无法将客户端发送的字符串转换为正确的枚举。 (待处理、已使用等)。

有没有一种方法可以解决这个问题,即使用 Spring Data REST 的内部设施(我指出枚举转换在 save() 方法中工作)的优雅方式,而不需要重新发明轮子?

最佳答案

我最终以这种方式解决了这个问题:

  • 我创建了一个自定义@RepositoryRestController
  • 我创建了我的方法
  • 我从客户端获取枚举,就像字符串一样,然后将其转换。通过这种方式,客户端还可以发送枚举的翻译字符串

这是一段代码:

@PostMapping(path = "/licensePlates/searches")
public ResponseEntity<?> search(@RequestBody(required = true) List<Filter> filters, Pageable pageable, Locale locale,
PersistentEntityResourceAssembler resourceAssembler) {
EngineType engineType = enumTranslator.fromText(EngineType.class, filterMap.get("engineType"));

您必须以这种方式注入(inject) enumTranslation:

@Autowired
private EnumTranslator enumTranslator;

不确定这是最好的方法,但用很少的代码解决了我的问题。

关于java - Spring Data REST 存储库中的枚举翻译,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45106815/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com