精通Spring │ WebFlux框架的函数式开发模式

简介: WebFlux框架的函数式开发模式

640.jpg

01、WebFlux框架的函数式开发模式

所谓函数式开发模式,是和面向对象开发模式相对的一个概念。在面向对象的开发模式中,对象是程序中的主角,程序在运行时会创建各种对象,这些对象产生各种行为,彼此之间互相协作,最后产生运算结果。而在函数式开发模式中,实现特定功能的各种方法是程序中的主角,一个接一个的方法被调用,环环相扣,最后产生运算结果,就像生产流水线一样,而至于到底是哪些对象来提供这些方法,可以被忽略。

例如以下代码中的Lambda表达式就体现了函数式编程思想,Lambda表达式定义了处理所接收到的数据的功能,而至于这些功能属于哪个匿名对象,在这里被忽略:

//发送方发送“Hello”字符串
Mono<String> mono=Mono.just(“Hello”);
 
//接收方按照异步非阻塞方式接收“Hello”字符串
mono.subscribe(
  value -> System.out.println(value),
  error -> error.printStackTrace()
);

由于Java语言本质是面向对象的开发语言,因此,程序在引入函数式开发模式时,实际上是面向对象开发和函数式开发两种模式夹杂在一起。

在WebFlux框架的函数式开发模式中,控制器类是任意的用@Component组件标识的类。以下例程1的DataHandler类就是控制器类。

例程1 DataHandler.java

……
import static org.springframework.web.reactive
                            .function.server.ServerResponse.ok;
@Component
public class DataHandler {
  public Mono<ServerResponse> greet(ServerRequest request) {
    StringcurrentTime="Now is "
 
       + newSimpleDateFormat("HH:mm:ss").format(new Date());
 
 
    returnok().contentType(MediaType.TEXT_PLAIN)
 
              .body(Mono.just(currentTime),String.class);
 
  }
 
  publicMono<ServerResponse> count(ServerRequest request) {
 
   List<Integer> scores=new ArrayList<Integer>();
 
    for(inti=0;i<100000;i++)
 
     scores.add(i);
 
 
   Flux<Integer> data=Flux.fromIterable(scores);
 
 
    returnok()
 
              .contentType(MediaType.APPLICATION_STREAM_JSON)
 
              .body(data,Integer.class);
 
  }
 
  publicMono<ServerResponse> push(ServerRequest request) {
 
   List<Integer> scores=new ArrayList<Integer>();
 
    for(inti=0;i<100000;i++)
 
     scores.add(i);
 
 
    //间隔5秒发送一次数据
   Flux<Integer> data=Flux.interval(Duration.ofSeconds(5))
 
                               .fromIterable(scores);
 
    returnok()
 
               .contentType(MediaType.TEXT_EVENT_STREAM)
 
               .body(data,Integer.class);
 
  }
}

DataHandler类的请求处理方法有一个表示客户请求的ServerRequest类型的请求参数,返回类型是Mono类型。

DataHandler类的greet()、count()和push()方法分别返回不同类型的响应结果:

1.MediaType.TEXT_PLAIN:纯文本类型。

2.MediaType.APPLICATION_STREAM_JSON:JSON格式的异步非阻塞的数据流。

3.MediaType.TEXT_EVENT_STREAM:事件驱动的异步非阻塞的文本数据流。

以DataHandler类的greet()方法为例,它的以下代码体现了函数式编程的思想:

import static org.springframework.web.reactive
                       .function.server.ServerResponse.ok;
 
……
return ok().contentType(MediaType.TEXT_PLAIN)
                .body(Mono.just(currentTime),String.class);

以上ok()方法是静态引入的方法,具有返回正常响应结果的功能,接下来又调用contentType()和body()方法来设置响应结果的数据类型和正文内容。产生整个运算结果是由一系列的方法调用来产生的,对象在程序中的主导地位被削弱了,这就体现了函数式编程的思想。

DataHandler类没有用@Controller注解来标识,所以不能用@RequestMapping等注解来为它的请求处理方法设定映射路径。那么在这种情况下,该如何为请求处理方法设定映射路径呢?用RouterFunction路由函数接口来设定映射路径,也称作设定路由。

在以下例程2的DataRouter类中,为DataHandler类的三个请求处理方法均设定了路由。

例程2 DataRouter.java

@Configuration
public class DataRouter {
  @Bean
  public RouterFunction<ServerResponse> route(
                            DataHandler dataHandler) {
 
    returnRouterFunctions
 
     .route(RequestPredicates.GET("/greet")
 
     .and(RequestPredicates.accept(MediaType.TEXT_PLAIN))
 
                                                       ,dataHandler::greet)
 
     .andRoute(RequestPredicates.GET("/push")
 
     .and(RequestPredicates.accept(
 
                                        MediaType.TEXT_EVENT_STREAM))
 
                                        ,dataHandler::push)
 
     .andRoute(RequestPredicates.GET("/count")
 
     .and(RequestPredicates.accept(
 
                          MediaType.APPLICATION_STREAM_JSON)),
                          dataHandler::count);
    }
}

DataRouter类用@Configuration注解来标识,表明DataRouter类属于配置类,因此Spring框架在启动时会把DataRouter类设定的路由加载到内存中。root()方法用@Bean注解标识,表明root()方法返回的RouterFunction对象会作为Bean组件注册到Spring框架中。

在Intellij IDEA中运行本范例程序,DataRouter类为DataHandler类的greet()、push()和count()方法设定的映射路径分别为:

http://localhost:8080/greet

http://localhost:8080/push

http://localhost:8080/count

目录
相关文章
|
29天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
2月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
48 4
|
2月前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
38 0
|
2月前
|
前端开发 Java 数据库连接
Spring 框架:Java 开发者的春天
Spring 框架是一个功能强大的开源框架,主要用于简化 Java 企业级应用的开发,由被称为“Spring 之父”的 Rod Johnson 于 2002 年提出并创立,并由Pivotal团队维护。
52 1
Spring 框架:Java 开发者的春天
|
25天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
44 2
|
2月前
|
人工智能 Java API
阿里云开源 AI 应用开发框架:Spring AI Alibaba
近期,阿里云重磅发布了首款面向 Java 开发者的开源 AI 应用开发框架:Spring AI Alibaba(项目 Github 仓库地址:alibaba/spring-ai-alibaba),Spring AI Alibaba 项目基于 Spring AI 构建,是阿里云通义系列模型及服务在 Java AI 应用开发领域的最佳实践,提供高层次的 AI API 抽象与云原生基础设施集成方案,帮助开发者快速构建 AI 应用。本文将详细介绍 Spring AI Alibaba 的核心特性,并通过「智能机票助手」的示例直观的展示 Spring AI Alibaba 开发 AI 应用的便利性。示例源
|
24天前
|
消息中间件 NoSQL Java
springboot整合常用中间件框架案例
该项目是Spring Boot集成整合案例,涵盖多种中间件的使用示例,每个案例项目使用最小依赖,便于直接应用到自己的项目中。包括MyBatis、Redis、MongoDB、MQ、ES等的整合示例。
81 1
|
2月前
|
人工智能 开发框架 Java
总计 30 万奖金,Spring AI Alibaba 应用框架挑战赛开赛
Spring AI Alibaba 应用框架挑战赛邀请广大开发者参与开源项目的共建,助力项目快速发展,掌握 AI 应用开发模式。大赛分为《支持 Spring AI Alibaba 应用可视化调试与追踪本地工具》和《基于 Flow 的 AI 编排机制设计与实现》两个赛道,总计 30 万奖金。
|
2月前
|
Java 数据库连接 开发者
Spring 框架:Java 开发者的春天
【10月更文挑战第27天】Spring 框架由 Rod Johnson 在 2002 年创建,旨在解决 Java 企业级开发中的复杂性问题。它通过控制反转(IOC)和面向切面的编程(AOP)等核心机制,提供了轻量级的容器和丰富的功能,支持 Web 开发、数据访问等领域,显著提高了开发效率和应用的可维护性。Spring 拥有强大的社区支持和丰富的生态系统,是 Java 开发不可或缺的工具。
|
2月前
|
Java 数据库连接 数据库
让星星⭐月亮告诉你,SSH框架01、Spring概述
Spring是一个轻量级的Java开发框架,旨在简化企业级应用开发。它通过IoC(控制反转)和DI(依赖注入)降低组件间的耦合度,支持AOP(面向切面编程),简化事务管理和数据库操作,并能与多种第三方框架无缝集成,提供灵活的Web层支持,是开发高性能应用的理想选择。
38 1
下一篇
无影云桌面