Chr*_*Geo 13 rest spring spring-data-rest spring-hateoas
我想为一个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;
}
Run Code Online (Sandbox Code Playgroud)
所以我想让我们说一下我可以做的查询:
http://localhost:8080/myApp/employees/search/all?firstName=me&lastName=self&ageFrom=20&ageTo=30&hiringDateFrom=12234433235
Run Code Online (Sandbox Code Playgroud)
所以我有以下内容 Repository
@RepositoryRestResource(collectionResourceRel="employees", path="employees")
public interface EmployeeRepository extends PagingAndSortingRepository<Employee, Long>,
JpaSpecificationExecutor<Employee> {
}
Run Code Online (Sandbox Code Playgroud)
好的,现在我需要一个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);
}
Run Code Online (Sandbox Code Playgroud)
好吧,显然这可以完成它的工作,但它没有与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);
}
Run Code Online (Sandbox Code Playgroud)
显然,我错过了上面的内容,因为它不起作用,我得到以下例外:
Could not instantiate bean class [org.springframework.data.web.PagedResourcesAssembler]: No default constructor found;
Run Code Online (Sandbox Code Playgroud)
好吧,为了使问题清楚,我正在尝试将上述资源集成到HATEOAS架构的其余部分.我不完全确定这是否是正确的方法,所以欢迎任何其他建议.
编辑:在这里您可以看到类似的实现.请查看配置,您将看到除"一个"控制器之外的所有控制器都正常工作. https://github.com/cgeo7/spring-rest-example
Sta*_*007 16
尝试将autowring 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);
}
}
Run Code Online (Sandbox Code Playgroud)
这与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);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11125 次 |
| 最近记录: |