Akce
Spring REST Controller » Historie » Revize 8
« Předchozí |
Revize 8/10
(rozdíl)
| Další »
Jiří Trefil, 2023-03-15 22:33
Spring REST Controller¶
- Controller řídí logiku toku informací aplikace s MVC architekturou, tedy řídí, jak uživatel s aplikací komunikuje. Rozhoduje, jaký response odeslat na konkrétní uživatelský request.
- Spring aplikace v kontextu SPADe v2 je pouze RESTové API, všechny controllery jsou tedy anotovány pomocí @RestController. Tato anotace implikuje, že třída je REST controller (správná konvence).
- Každý controller bude vracet response skládající se z HTTP stavového kódu (nese informaci o výsledku operace) a JSON objekt obsahující libovolného relevantní informace.
Příklad REST controlleru (TODO REPLACE template controlleru, až bude nějaký ustálený)¶
// anotace RestController - říká, že třída DummyController je REST controllerem
@RestController
public class DummyController {
// RequestMapping - velice prostá anotace, která říká, že HTTP request je mapován na konkrétní metodu
// V tomto případě je HTTP request na localhost/v2/helloworld mapován na tento controller a na metodu HelloWorld
// value - konkrétní path, na které je tato metoda pověšena
// produce - co controller vrací (Content-type v headeru response objektu), tady slibujeme, že vracíme JSON
// method - na jaký typ requestu posloucháme, v tomto případě GET
@RequestMapping(value = "/v2/helloworld", produces="application/json", method = RequestMethod.GET)
public String helloWorld(@RequestParam(value = "parameter", defaultValue=" World") String parameter){
// zde samotný kód, který zpracuje request
// je maximálně vhodné z controlleru volat nějakou service, která reprezentuje logiku aplikace a nevykonávat zde nic těžkého
// tedy zde jenom přijmu request, předám ho service, od service dostanu výsledek a odpovím
return "{\"message\":\"Hello "+parameter+"\"}";
}
//zde pouze změna v method
// method - POST - touto metodou budeme odpovídat na requesty typu POST. Zbytek platí stejně jako u metody výše.
@RequestMapping(value = "/v2/helloworld", produces="application/json", method = RequestMethod.POST)
public String goodbyeWorld(@RequestParam(value = "parameter", defaultValue=" World") String parameter){
// zde samotný kód, který zpracuje request
// tedy zde jenom přijmu request, předám ho service, od service dostanu výsledek a odpovím
return "{\"message\":\"Bye "+parameter+"\"}";
}
}
Dvě hlavní anotace controllerů a jakou použít¶
- Existují dvě anotace, které je možné použít při vytváření RESTful aplikace. @Controller a @RestController. Anotace @Controller je více generická a označuje obecný controller - ne nutně REST controller!
- Druhá anotace pohodlně slučuje dohromady anotaci @Controller a @ResponseBody. Aplikace je čitelnější - programátor ví, že následující třída je právě REST controller a ví, jaké chování může očekávat.
Aktualizováno uživatelem Jiří Trefil před asi 2 roky(ů) · 8 revizí