Spring WebFlux的使用指南
Spring WebFlux是spring5的一部分,它為web應用程序提供反應式編程支持。
在本教程中,我們將使用RestController和WebClient創建一個小型響應式REST應用程序。
我們還將研究如何使用Spring安全保護我們的反應端點。
Spring-WebFlux框架
Spring WebFlux在內部使用Project Reactor及其發佈者實現Flux和Mono。
新框架支持兩種編程模型:
- 基於註釋的反應元件
- 功能路由和處理
依賴項
讓我們從spring boot starter webflux依賴項開始,它包含所有其他必需的依賴項:
- spring boot和spring boot starter,用於基本的spring boot應用程序設置
- spring-webflux框架
- reactor-core我們需要的反應流,也需要reactor-netty
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-webflux</artifactId> <version>2.2.6.RELEASE</version> </dependency>
響應式應用
我們現在將使用Spring WebFlux構建一個非常簡單的REST EmployeeManagement應用程序:
- 我們將使用一個簡單的域模型-帶有id和name字段的Employee
- 我們將使用RestController構建restapi,以將員工資源作為單個資源和集合發佈
- 我們將使用WebClient構建一個客戶端來檢索相同的資源
- 我們將使用WebFlux和Spring Security創建一個安全的被動端點
響應式RestController
springwebflux支持基於註釋的配置,方式與springwebmvc框架相同。
首先,在服務器上,我們創建一個帶註釋的控制器,它發佈員工資源的反應流。
讓我們創建帶註釋的EmployeeController
:
@RestController @RequestMapping("/employees") public class EmployeeController { private final EmployeeRepository employeeRepository; // constructor... }
EmployeeRepository可以是任何支持非阻塞反應流的數據存儲庫。
單一資源
讓我們在控制器中創建一個端點,用於發佈單個員工資源:
@GetMapping("/{id}") private Mono<Employee> getEmployeeById(@PathVariable String id) { return employeeRepository.findEmployeeById(id); }
我們在Mono中包裝一個Employee資源,因為我們最多返回一個Employee。
集合資源
我們還要添加一個端點來發佈所有雇員的集合資源:
@GetMapping private Flux<Employee> getAllEmployees() { return employeeRepository.findAllEmployees(); }
對於集合資源,我們使用類型為Employee的流量,因為它是0..n元素的發佈者。
反應式Web客戶端
Spring5中引入的WebClient是一個支持反應流的非阻塞客戶端。
我們可以使用WebClient創建一個客戶端,從EmployeeController提供的端點檢索數據。
讓我們創建一個簡單的EmployeeWebClient:
public class EmployeeWebClient { WebClient client = WebClient.create("http://localhost:8080"); // ... }
在這裡,我們使用工廠方法create創建瞭一個WebClient。它會指向localhost:8080,所以我們可以使用或相對的URL來調用這個客戶端實例。
檢索單個資源
要從endpoint/employee/{id}檢索Mono類型的單個資源,請執行以下操作:
Mono<Employee> employeeMono = client.get() .uri("/employees/{id}", "1") .retrieve() .bodyToMono(Employee.class); employeeMono.subscribe(System.out::println);
檢索集合資源
類似地,要從endpoint/employees檢索Flux類型的集合資源,請執行以下操作:
Flux<Employee> employeeFlux = client.get() .uri("/employees") .retrieve() .bodyToFlux(Employee.class); employeeFlux.subscribe(System.out::println);
Spring WebFlux安全性
我們可以使用Spring Security來保護我們的反應端點。
假設我們在EmployeeController中有一個新的端點。此端點更新員工詳細信息並發回更新的員工。
由於這允許用戶更改現有員工,因此我們希望僅將此端點限制為管理員角色用戶。
讓我們為EmployeeController添加一個新方法:
@PostMapping("/update") private Mono<Employee> updateEmployee(@RequestBody Employee employee) { return employeeRepository.updateEmployee(employee); }
現在,為瞭限制對該方法的訪問,讓我們創建SecurityConfig並定義一些基於路徑的規則以僅允許管理員用戶:
@EnableWebFluxSecurity public class EmployeeWebSecurityConfig { // ... @Bean public SecurityWebFilterChain springSecurityFilterChain( ServerHttpSecurity http) { http.csrf().disable() .authorizeExchange() .pathMatchers(HttpMethod.POST, "/employees/update").hasRole("ADMIN") .pathMatchers("/**").permitAll() .and() .httpBasic(); return http.build(); } }
此配置將限制對/employees/update的訪問。因此,隻有具有ADMIN角色的用戶才能訪問此端點並更新現有員工。
最後,註解@EnableWebFluxSecurity添加瞭一些默認配置的Spring-Security-WebFlux支持。
結論
在本文中,我們探討瞭如何創建和使用springwebflux框架支持的反應式web組件。例如,我們構建瞭一個小型的REST應用程序。
除瞭Reactive RestController和WebClient之外,WebFlux框架還支持Reactive WebSocket和對應的WebSocketClient,以進行套接字樣式的Reactive流。
最後,在Github上提供瞭本文中使用的完整源代碼:https://github.com/eugenp/tutorials/tree/master/spring-5-reactive-security
以上就是Spring WebFlux的使用指南的詳細內容,更多關於Spring WebFlux的使用的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- SpringBoot深入分析webmvc和webflux的區別
- spring webflux自定義netty 參數解析
- SpringMVC RESTFul實體類創建及環境搭建
- Java反應式框架Reactor中的Mono和Flux
- Java進階之走進RESTful接口