Projekt

Obecné

Profil

Spring REST Controller » Historie » Verze 8

Jiří Trefil, 2023-03-15 22:33

1 1 Jiří Trefil
h1. Spring REST Controller
2 2 Jiří Trefil
3
* 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.
4
* 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).
5 6 Jiří Trefil
* 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.
6 3 Jiří Trefil
7 5 Jiří Trefil
h2. Příklad REST controlleru (TODO REPLACE template controlleru, až bude nějaký ustálený)
8 3 Jiří Trefil
9
10 1 Jiří Trefil
<pre><code class="java">
11 4 Jiří Trefil
 
12
// anotace RestController - říká, že třída DummyController je REST controllerem
13
@RestController
14 3 Jiří Trefil
public class DummyController {
15 4 Jiří Trefil
    // RequestMapping - velice prostá anotace, která říká, že HTTP request je mapován na konkrétní metodu
16
    // V tomto případě je HTTP request na localhost/v2/helloworld mapován na tento controller a na metodu HelloWorld
17
    // value - konkrétní path, na které je tato metoda pověšena
18
    // produce - co controller vrací (Content-type v headeru response objektu), tady slibujeme, že vracíme JSON
19
    // method - na jaký typ requestu posloucháme, v tomto případě GET
20
    @RequestMapping(value = "/v2/helloworld", produces="application/json", method = RequestMethod.GET)
21 1 Jiří Trefil
    public String helloWorld(@RequestParam(value = "parameter", defaultValue=" World") String parameter){
22 4 Jiří Trefil
        // zde samotný kód, který zpracuje request
23
        // je maximálně vhodné z controlleru volat nějakou service, která reprezentuje logiku aplikace a nevykonávat zde nic těžkého
24
        // tedy zde jenom přijmu request, předám ho service, od service dostanu výsledek a odpovím
25 1 Jiří Trefil
        return "{\"message\":\"Hello "+parameter+"\"}";
26 4 Jiří Trefil
    }
27
    //zde pouze změna v method
28
    // method - POST - touto metodou budeme odpovídat na requesty typu POST. Zbytek platí stejně jako u metody výše.
29
    @RequestMapping(value = "/v2/helloworld", produces="application/json", method = RequestMethod.POST)
30
    public String goodbyeWorld(@RequestParam(value = "parameter", defaultValue=" World") String parameter){
31
        // zde samotný kód, který zpracuje request
32
        // tedy zde jenom přijmu request, předám ho service, od service dostanu výsledek a odpovím
33
        return "{\"message\":\"Bye "+parameter+"\"}";
34 3 Jiří Trefil
    }
35
36 2 Jiří Trefil
}
37 1 Jiří Trefil
</code></pre>
38 7 Jiří Trefil
39 8 Jiří Trefil
h2. Dvě hlavní anotace controllerů a jakou použít
40 7 Jiří Trefil
41
* 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!
42
* 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*.