基本的にEmployee
クエリとなるfindByAllFields
エンティティのRESTリンクを作成したい。もちろん、これはPage
およびSort
と組み合わせる必要があります。これを行うために、次のコードを実装しました。 :
@Entity
public class Employee extends Persistable<Long> {
@Column
private String firstName;
@Column
private String lastName;
@Column
private String age;
@Column
@Temporal(TemporalType.TIMESTAMP)
private Date hiringDate;
}
だから私は私ができる場所でクエリを言ってもらいたいと思います:
http://localhost:8080/myApp/employees/search/all?firstName=me&lastName=self&ageFrom=20&ageTo=30&hiringDateFrom=12234433235
だから私は次のRepository
を持っています
@RepositoryRestResource(collectionResourceRel="employees", path="employees")
public interface EmployeeRepository extends PagingAndSortingRepository<Employee, Long>,
JpaSpecificationExecutor<Employee> {
}
さて、RestControllerが必要です
@RepositoryRestController
public class EmployeeSearchController {
@Autowired
private EmployeeRepository employeRepository;
@RequestMapping(value = "/employees/search/all/search/all", method = RequestMethod.GET)
public Page<Employee> getEmployees(EmployeeCriteria filterCriteria, Pageable pageable) {
//EmployeeSpecification uses CriteriaAPI to form dynamic query with the fields from filterCriteria
Specification<Employee> specification = new EmployeeSpecification(filterCriteria);
return employeeRepository.findAll(specification, pageable);
}
わかりました、明らかにこれはその仕事をしますがそれはHATEOASと統合されていません。コントローラを次のように変更して、リソースを組み立てようとしました。
public PagedResources<Resource<Employee>> getEmployees(
PagedResourcesAssembler<Employee> assembler,
EmployeeCriteria filterCriteria, Pageable pageable) {
//EmployeeSpecification uses CriteriaAPI to form dynamic query with the fields from filterCriteria
Specification<Employee> specification = new EmployeeSpecification(filterCriteria);
Page<Employee> employees = employeeRepository.findAll(specification, pageable);
return assembler.toResource(employees);
}
明らかに、それが機能せず、次の例外が発生するため、上記の何かが欠けています:
Could not instantiate bean class [org.springframework.data.web.PagedResourcesAssembler]: No default constructor found;
質問を明確にするために上記のリソースを残りのHATEOASアーキテクチャに統合しようとしています。これが正しいかどうかは完全にはわかりません。正しいアプローチなので、他の提案は大歓迎です。
編集:ここでは、同様の実装を見ることができます。構成を見てください。1つを除くすべての「Person」コントローラーが機能していることがわかります。 https://github.com/cgeo7/spring-rest-example
クラスメンバーとしてPagedResourcesAssembler
を自動書き込みしてみて、メソッドシグネチャを次のように変更してください
@RepositoryRestController
public class EmployeeSearchController {
@Autowired
private EmployeeRepository employeRepository;
@Autowired
private PagedResourcesAssembler<Employee> pagedAssembler;
@RequestMapping(value = "/employees/search/all/search/all", method = RequestMethod.GET)
public ResponseEntity<Resources<Resource<Employee>>> getEmployees(EmployeeCriteria filterCriteria, Pageable pageable) {
//EmployeeSpecification uses CriteriaAPI to form dynamic query with the fields from filterCriteria
Specification<Employee> specification = new EmployeeSpecification(filterCriteria);
Page<Employee> employees = employeeRepository.findAll(specification, pageable);
return assembler.toResource(employees);
}
}
これはSpring Data Rest 2.1.4.RELEASEで完全に機能します
@ Stackee007によるコードは機能しますが、リソースにはself
リンクは含まれません。そのためには、もう少し必要です。
@Autowired
PagedResourcesAssembler<Appointment> pagedResourcesAssembler;
@RequestMapping(value = "/findTodaysSchedule")
public HttpEntity<PagedResources<Resource<Appointment>>> getTodaysSchedule(
PersistentEntityResourceAssembler entityAssembler, Pageable pageable) {
Page<Appointment> todaysSchedule = apptRepo.findByStartTimeBetween(beginningOfDay, endOfDay, pageable);
@SuppressWarnings({ "unchecked", "rawtypes" })
PagedResources<Resource<Appointment>> resource = pagedResourcesAssembler.toResource(todaysSchedule,
(ResourceAssembler) entityAssembler);
return new ResponseEntity<>(resource, HttpStatus.OK);
}