13

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 アーキテクチャに統合しようとしています。これが正しいアプローチであるかどうかは完全にはわかりませんので、他の提案は大歓迎です。

編集: ここで同様の実装を見ることができます。構成を見てください。「Person」コントローラーの 1 つを除くすべてが機能していることがわかります。 https://github.com/cgeo7/spring-rest-example

4

3 に答える 3

18

クラス メンバーとして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 と完全に連携します。

于 2014-09-29T16:08:26.187 に答える
6

@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);
}
于 2015-10-20T05:28:22.400 に答える