Pracuję z Spring Framework 4.0.7, wraz z MVC i resztaKiedy użycie ResponseEntity <T> i @RestController na wiosnę aplikacji REST
mogę pracować w spokoju z:
@Controller
ResponseEntity<T>
Na przykład:
@Controller
@RequestMapping("/person")
@Profile("responseentity")
public class PersonRestResponseEntityController {
Dzięki metodzie (tylko stworzyć)
@RequestMapping(value="/", method=RequestMethod.POST)
public ResponseEntity<Void> createPerson(@RequestBody Person person, UriComponentsBuilder ucb){
logger.info("PersonRestResponseEntityController - createPerson");
if(person==null)
logger.error("person is null!!!");
else
logger.info("{}", person.toString());
personMapRepository.savePerson(person);
HttpHeaders headers = new HttpHeaders();
headers.add("1", "uno");
//http://localhost:8080/spring-utility/person/1
headers.setLocation(ucb.path("/person/{id}").buildAndExpand(person.getId()).toUri());
return new ResponseEntity<>(headers, HttpStatus.CREATED);
}
powrócić coś
@RequestMapping(value="/{id}", method=RequestMethod.GET)
public ResponseEntity<Person> getPerson(@PathVariable Integer id){
logger.info("PersonRestResponseEntityController - getPerson - id: {}", id);
Person person = personMapRepository.findPerson(id);
return new ResponseEntity<>(person, HttpStatus.FOUND);
}
Works fine
mogę zrobić to samo z:
@RestController
(wiem, że to jest to samo niż@Controller
+@ResponseBody
)@ResponseStatus
Na przykład:
@RestController
@RequestMapping("/person")
@Profile("restcontroller")
public class PersonRestController {
Z metody (wystarczy stworzyć)
@RequestMapping(value="/", method=RequestMethod.POST)
@ResponseStatus(HttpStatus.CREATED)
public void createPerson(@RequestBody Person person, HttpServletRequest request, HttpServletResponse response){
logger.info("PersonRestController - createPerson");
if(person==null)
logger.error("person is null!!!");
else
logger.info("{}", person.toString());
personMapRepository.savePerson(person);
response.setHeader("1", "uno");
//http://localhost:8080/spring-utility/person/1
response.setHeader("Location", request.getRequestURL().append(person.getId()).toString());
}
do Zwróć coś
@RequestMapping(value="/{id}", method=RequestMethod.GET)
@ResponseStatus(HttpStatus.FOUND)
public Person getPerson(@PathVariable Integer id){
logger.info("PersonRestController - getPerson - id: {}", id);
Person person = personMapRepository.findPerson(id);
return person;
}
Moje pytania są następujące:
- gdy solidnego powodu lub specyficzny scenariusz jedna opcja powinna być stosowana obowiązkowo nad drugą
- Jeśli (1) nie ma znaczenia, jakie podejście jest zasugerował i dlaczego.
dobry punkt o trzeciej obserwacji. Dziękuję ... i pomyślałem to samo o "ResponseEntity", jest bardziej elastyczny. Właśnie miałem wątpliwości dotyczące '@ RestController'. Dziękujemy –