Spring Интеграция пользовательских запросов REST данных
Я хочу создать ссылку REST для объекта Employee
, который будет в основном быть запросом findByAllFields
. Конечно, это должно сочетаться с 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. Я не совсем уверен, что это правильный подход, поэтому любые другие предложения приветствуется.
EDIT:
Здесь вы можете увидеть аналогичную реализацию. Пожалуйста, взгляните на конфигурацию, вы увидите, что все, кроме одного из "Персональных" контроллеров, работают.
https://github.com/cgeo7/spring-rest-example
Ответы
Ответ 1
Попробуйте 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);
}
}
Это отлично работает с Spring Data Rest 2.1.4.RELEASE
Ответ 2
Код @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);
}
Ответ 3
Я никогда не использовал данные spring, и я не очень понимаю его, но есть новый проект из spring http://projects.spring.io/spring-hateoas/, который я использовал в службе spring MVC REST и работает очень хорошо.