您好我已经公开了一个自定义的@RepositoryRestController来通过Spring数据公开一个自定义方法,该方法的代码如下所示
@RequestMapping(method = RequestMethod.GET, value = "/foo/rsqlsearch")
public @ResponseBody PagedResources<Resource<Foos>> findAllPaged(@RequestParam(value = "rsql") String rsql, Pageable pageable) {
Page<Foo> foos= fundRepository.searchByRsql(rsql, pageable);
return pagedResourcesAssembler.toResource(foos);
}
foo实体
@Entity
@Table(name = "FOO_TBL", schema = "F")
@Data
public class Foo implements Identifiable<String> {
@Id
@Column(name = "ID")
@Description("Id")
private String id;
// associations
@OneToMany(mappedBy = "foo", fetch = FetchType.LAZY)
private List<FooFriends> fooFriends;
@OneToMany(mappedBy = "foo", fetch = FetchType.LAZY)
private List<Marks> marks;
}
Foo实体使用来自自定义存储库方法的数据呈现正常。但是json表示不包含指向实体的关联的链接。是否有一种方法可以通过框架公开这些关联编写自定义ResourceProcessor就像在Spring数据休息的其他现成表示中一样。
答案 0 :(得分:4)
最后,我通过一些Spring数据休息代码解决了这个问题。为了实现这一点,我从AbstractRepositoryRestController这一部分得到了这个,让我了解了如何同时使用PersistentEntityResourceAssembler和pagedResourcesAssembler。
@SuppressWarnings({ "unchecked" })
protected Resources<?> toResources(Iterable<?> source, PersistentEntityResourceAssembler assembler,
Class<?> domainType, Link baseLink) {
if (source instanceof Page) {
Page<Object> page = (Page<Object>) source;
return entitiesToResources(page, assembler, domainType, baseLink);
} else if (source instanceof Iterable) {
return entitiesToResources((Iterable<Object>) source, assembler, domainType);
} else {
return new Resources(EMPTY_RESOURCE_LIST);
}
}
所以在使用restm方法中提供的PersistentEntityResourceAssembler之后,我终于可以为我的自定义查询提供spring数据休息HAl类型代表。下面的代码
@RequestMapping(method = RequestMethod.GET, value = "/foo/rsqlsearch")
public @ResponseBody PagedResources<?> findAllPaged(@RequestParam(value = RSQL_REL) String rsql,
Pageable pageable,
PersistentEntityResourceAssembler eass) {
Page<Object> entities = (Page<Object>) repository.searchByRsql(rsql, pageable);
return assembler.toResource(entities, eass);
}
希望它可以帮助周围的人:)