WebFlux02 SpringBoot WebFlux项目骨架搭建

 

1 环境搭建

  1.1 版本说明

    jdk -> 1.8

    maven -3.5 

    springboot -> 2.0.3

    开发工具 -> IDEA

  1.2 创建项目

    利用 IDEA 或者 start.spring.io 创建一个SpringBoot项目

    1.2.1 选择依赖

      

    1.2.2 pom.xml 依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>cn.xiangxu</groupId><artifactId>test_demo</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>test_demo</name><description>Demo project for Spring Boot</description><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.3.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><!--<scope>runtime</scope>--><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>io.projectreactor</groupId><artifactId>reactor-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><configuration><fork>true</fork></configuration></plugin></plugins></build></project>
View Code

 

2 开发步骤

  2.1 处理器类

    相当于SpringMVC中的service类,主要就是根据不同的请求url执行不同的业务逻辑

    技巧01:编写的处理器类必须被容器所管理

package cn.xiangxu.test_demo.handler;import org.springframework.http.MediaType;
import org.springframework.stereotype.Component;
import org.springframework.web.reactive.function.BodyInserters;
import org.springframework.web.reactive.function.server.ServerRequest;
import org.springframework.web.reactive.function.server.ServerResponse;
import reactor.core.publisher.Mono;/*** @author 王杨帅* @create 2018-06-26 9:58* @desc 相当于springMVC的controller类**/
@Component
public class StudentHandler {public Mono<ServerResponse> helloStudent(ServerRequest serverRequest) {return ServerResponse // 响应对象封装.ok() // 响应码.contentType(MediaType.TEXT_PLAIN) // 响应类型.body(BodyInserters.fromObject("这是学生控制类")); // 响应体
    }}
StudentHandler.java

  2.2 路由器类

    相当于DispatherServlet,主要就是将不同的请求url和对应的处理器类进行匹配

    技巧01:路由器类相当于一个Java配置类,所以必须添加 @Configuration 注解,并且路由器类中的路由方法返回的对象必须被容器管理,所以必须添加@Bean注解

    技巧02:RouterFunctions的route方法接收两个参数,并返回 RouterFunctions 类型

      》参数一 :请求断言

      》参数二 :处理函数接口【可用lambda表达式代替】

package cn.xiangxu.test_demo.router;import cn.xiangxu.test_demo.handler.StudentHandler;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.MediaType;
import org.springframework.web.reactive.function.server.RequestPredicates;
import org.springframework.web.reactive.function.server.RouterFunction;
import org.springframework.web.reactive.function.server.RouterFunctions;
import org.springframework.web.reactive.function.server.ServerResponse;/*** @author 王杨帅* @create 2018-06-26 10:02* @desc**/
@Configuration
public class StudentRouter {@Beanpublic RouterFunction<ServerResponse> routerHelloStudent(StudentHandler studentHandler) {return RouterFunctions.route( // 路由匹配:将请求url路由到对应的处理器
                        RequestPredicates.GET("/student/hello") // 请求url.and(RequestPredicates.accept(MediaType.TEXT_PLAIN)), // 接收的请求数据类型studentHandler::helloStudent // 处理请求的处理方法
                );/*代码解释:如果请求是/student/hello时就会调用StudentHandler处理器类中的helloStudent方法进行业务逻辑处理*/}
}
StudentRouter.java

  2.3 启动项目

    2.3.1 IDEA启动

      直接运行启动类就可以啦

    2.3.2 打包部署启动

      》打包项目

      

      》运行项目

        进入到项目根目录下的target文件夹后通过 java -jar xxx.jar 就可以运行项目啦

        技巧01:SpringBoot WebFlux 默认集成的是 Netty 

        

    2.3.3 前端访问

      

 

转载于:https://www.cnblogs.com/NeverCtrl-C/p/9227846.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/266797.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机专业 拒绝清华,高分拒绝清华北大怎么回事 为什么会拒绝

原标题&#xff1a;高分拒绝清华北大怎么回事 为什么会拒绝今年有一位来自云南的考生在高考的时候考了712分&#xff0c;成功超过清华北大的投档线&#xff0c;要是换做别人都应该会很高兴&#xff0c;终于能够上万人瞩目的名牌大学了&#xff0c;但是这位学生却拒绝了北大清华…

linux top 命令可视化_Linux top命令使用详解:显示或管理执行中的程序

top命令可以实时动态地查看系统的整体运行情况&#xff0c;是一个综合了多方信息监测系统性能和运行信息的实用工具。通过top命令所提供的互动式界面&#xff0c;用热键可以管理。语法top(选项)选项-b&#xff1a;以批处理模式操作&#xff1b;-c&#xff1a;显示完整的治命令&…

新浪微博2-找到用户的accessToken

要想使用新浪微博的API&#xff0c;首先就必须获得用户的accessToken&#xff0c;否则什么都干不了。 在AuthorizeActivity中 String token values.getString("access_token"); String expires_in values.getString("expires_in"); …

五大板块(1)—— 数组的定义,赋值与应用

参考&#xff1a;五大板块&#xff08;1&#xff09;—— 数组的定义&#xff0c;赋值与应用 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-03-18 16:00:05 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/114981166 目录数组的定义及访问完…

计算机 用户创建失败,电脑用户加载错误,无法创建新的配置文件的解决方法...

这种无法创建新的配置文件&#xff0c;所以本地计算机中没有配置文件的用户都无法登录&#xff0c;而有配置文件的用户就可以登录。是因为创建新的用户配置文件时是把系统分区 Documents and Settings文件夹下的Default User文件夹(默认隐藏&#xff0c;需要设置显示隐藏文件夹…

css3-6 表格如何设置样式和定位样式是什么

css3-6 表格如何设置样式和定位样式是什么 一、总结 一句话总结&#xff1a;css可以解决所有属性设置的样式。 1、表格如何设置样式&#xff1f; css样式可以解决一切问题&#xff0c;没必要在表格上面加属性来设置样式。 7 table{8 width:1000px; 9 bor…

python flask 分页前后端分离_flask展示pyecharts图表前后端分离的问题

我按照pyecharts的官网案例学习flask&#xff0c;其中有段flask前后端分离的示例。官方教程&#xff1a;https://pyecharts.org/#/zh-cn...我用前后端分离展示柱状图、饼图都没问题&#xff0c;但把pyecharts的图形函数换成地理图表&#xff0c;就展示不出来&#xff0c;请问是…

Django学习笔记2:一个简单的开发实例

Technorati 标签: Python,Django目标&#xff1a;通过开发一个简单的Todo管理应用&#xff0c;熟悉Django的基本概念、和使用。 运行环境 Windows Vista Python 2.7 Django 1.5 准备工作 * 创建工程 python C:\Python27\Lib\site-packages\django\bin\django-admin.py startp…

五大板块(2)—— 指针

参考&#xff1a;五大板块&#xff08;2&#xff09;—— 指针 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-03-18 16:01:22 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/114981482 本文为学习笔记&#xff0c;整合课程内容及文章如下&…

基于word API 创建的可以打开word的自定义控件

代码基本框架来源&#xff1a; CSDN 博主&#xff1a;zjlovety的专栏 地址&#xff1a;https://blog.csdn.net/zjlovety/article/details/24463117 public partial class WinWordViewer : UserControl { public WinWordViewer() { Initializ…

台式计算机机箱都一样吗,别以为组装台式机很简单,机箱选择大有学问

原标题&#xff1a;别以为组装台式机很简单&#xff0c;机箱选择大有学问曾经组装台式机的时候对于机箱完全没有在意&#xff0c;总觉得随便选择一款就可以了&#xff0c; 而且是挑便宜的选择&#xff0c;而那些机箱有便宜也有贵&#xff0c;其实里面的设计完全不一样&#xff…

解压ubi文件_Linux 文件压缩与解压相关

tar [-cxtzjvfpPN] 文件与目录 ....参数&#xff1a;-c &#xff1a;建立一个压缩文件的参数指令-x &#xff1a;解开一个压缩文件的参数指令-t &#xff1a;查看压缩文件里面的文件特别注意&#xff1a; c/x/t 同时只能存在一个&#xff0c;原因是我们不可能同时压缩与解压缩。…

五大板块(3)—— 结构体

参考&#xff1a;五大板块&#xff08;3&#xff09;—— 结构体 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-03-18 16:02:43 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/114981743 目录结构体的三种定义赋值方法结构体数组结构体指针…

tp5更改入口文件到根目录的方法分享

tp5把入口文件放到了public目录中&#xff0c;对于服务器或者vps来说没啥&#xff0c;因为可以指定目录&#xff0c;但是对于虚拟主机就不行了&#xff0c;我们必须吧index.php这入口文件放到根目录&#xff0c;那么我么需要改一下相对的引入文件的路径就可以了&#xff0c;代码…

html 查找添加联系人,使用phonegap查找联系人的实现方法

实例如下&#xff1a;Database Exampledocument.addEventListener("deviceready", onDeviceReady, false);function onDeviceReady() {}function onSuccess(contacts){document.write(contacts.lengthcontacts found.);for(var i0;ifor(var j0;jdocument.write("…

实现连麦_微信年底放了个大招,视频号重磅升级,打赏直播连麦美颜抽奖齐上...

期待已久的视频号连麦功能来了。这次来的不仅有连麦功能&#xff0c;还有视频号打赏的微信豆体系&#xff0c;创作者想要的入口也有了。让我们一起来看看有什么新功能吧&#xff01;太长不看版本&#xff1a;「附近的人」变「附近的直播和人」连麦上线&#xff0c;还有美颜、抽…

【转】 .NET 打印水晶报表(CrystalReport)时,出现“查询引擎错误 C:/DO...

2019独角兽企业重金招聘Python工程师标准>>> 本地开发环境&#xff1a; Win XP, Visual Studio 2003 Oracle 项目背景&#xff1a; WinForm 工程&#xff0c;在一个表单中用Treeview控件显示 部门层级信息&#xff0c;然后有 按照相同格式&#xff08;layout…

洛谷 1226 取余运算||快速幂

洛谷 取余运算||快速幂 1226 其实比起楼下的大佬们&#xff0c;我主要是多了些位运算和讲解。 想法一&#xff1a; 直接输出 pow(b,q)%k 嗯~~勇气可嘉&#xff0c;但是看一眼数据范围&#xff08;长整型&#xff09;就会意识到&#xff0c;这个方法也许一个点都过不了。 想法二…

html5 查看图片,html5实现图片预览和查看原图

一、页面元素只有三个简单元素&#xff1a;拖拽区域二、添加简单的样式&#xff1a;.dragarea{width:300px;height:100px;background:#ddd;text-align:center;line-height:100px;}.drag_hover{background:rgba(0,0,0,.4) !important;}.item{width:300px;height:100px;float:lef…

五大板块(4)——链表

参考&#xff1a;五大板块&#xff08;4&#xff09;——链表 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-02-15 09:33:29 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/114981905 目录一、对比链表与数组同样是存放一串数据&#xff0…