10-WebFlux 实战城市管理系统

本篇内容我们会实现如下图所示的城市管理系统,因为上面案例都用的是 City,所以这里直接使用城市作为对象,写一个简单的城市管理系统,如图所示:

首先新生成一个项目:

可以看到,添加了web,数据库,视图三个依赖组件,清晰简单。


真个项目是一个简单的分层的增删改查系统,先来看实体类domain层:

可以看到,实体类设置了包括主键以内的四个属性,比较简单。


再来看dao层,

对MongoDB的操作,只需要继承ReactiveMongoRepository就可以,里面包含了默认的操作数据库的方法。包含了经典的增删改查操作。


再来看service层,包含了操作接口和实现类,

CityController 控制层使用注解驱动的模式来进行开发,代码如下:

可以创建不同功能的控制层,来处理不同的 HTTP 业务请求,比如 CityFrontController、CityAdminController 等分别处理不同场景的问题。

getCityList 方法:处理“/city”的 GET 请求,用来获取 City 列表。

getCity 方法:处理“/city/update/{id}”的 GET 请求,用来获取 City 信息。

postCity 方法:处理“/book/create”的 POST 请求,用来新建 Book 信息;通过 @ModelAttribut 绑定实体参数,也通过 @RequestBody @RequestParam 传递参数。

putCity 方法:处理“/update”的 PUT 请求,用来更新 City 信息,并使用 redirect 重定向到列表页面。


cityForm 提交表单页面表单页面如下:

利用的是 Thymeleaf 语法,上面章节也讲过具体使用方法,这里实现新增城市和更新城市两个操作。巧妙利用了 action 字段去动态判断请求是新增还是更新的控制层方法,然后进行 form 表单提交。



cityList 城市列表页面列表页面代码如下:


运行工程

一个  Spring Boot WebFlux 工程就开发完毕了,下面运行工程验证下。在 IDEA 中执行 Application 类启动,任意正常模式或者 Debug 模式,可以在控制台看到成功运行的输出:


打开浏览器,输入地址:http://localhost:8010/city,即打开城市列表页面:

然后新增,或者单击城市名称修改,到表单提交页面:


总结

这里,初步实现了小案例城市管理系统,基本满足日常的 CRUD 业务流程操作。上手教程只是上手,具体复杂逻辑,欢迎一起多交流学习。

(如果webflux在视图跳转中存在问题,建议使用rest接口异步实现)



我们的交流基地,“JAVA互联网技术交流:789650498”欢迎小伙伴们一起来交流:




原文:https://gitbook.cn/gitchat/column/5acda6f6d7966c5ae1086f2b/topic/5acdaaa5d7966c5ae10870ac



代码:https://gitee.com/blueses/springboot-webflux

你可能感兴趣的:(10-WebFlux 实战城市管理系统)