手写java简单框架_阿里微服务专家自己手写Spring Boot 实现一个简单的自动配置模块...

2019101710040_1.png

为了更好的理解 Spring Boot 的 自动配置和工作原理,我们自己来实现一个简单的自动配置模块。

假设,现在项目需要一个功能,需要自动记录项目发布者的相关信息,我们如何通过 Spring Boot 的自动配置,更好的实现功能呢?

实战的开端 – Maven搭建

先创建一个Maven项目,我来手动配置下 POM 文件。

2019101710040_2.png

参数的配置 – 属性参数类

首先,我们定义一个自定义前缀,叫做 custom 吧。之前说到,这里的配置参数,可以通过 application.properties 中直接设置。那么,我们创建一个作者的字段,设置默认值为 LiangGzone。

2019101710040_3.png

那么,聪明的你,应该想到了,我们在 application.properties 中配置的时候,就要这样配置了。

custom

custom.author = James

真的很简单 – 简单的服务类

2019101710040_4.png

你没有看错,真的是太简单了,没有高大上的复杂业务。它的主要用途就是赋值。

自动配置的核心 – 自动配置类

@ConditionalOnClass,参数中对应的类在 classpath 目录下存在时,才会去解析对应的配置类。因此,我们需要配置 AuthorServer 。

@EnableConfigurationProperties, 用来加载配置参数,所以它应该就是属性参数类

AuthorProperties。

2019101710040_5.png

authorResolver方法的作用,即 AuthorProperties 的参数赋值到AuthorServer 中。

spring.factories 不要遗漏

我们需要实现自定义自动装配,就需要自定义 spring.factories 参数。所以,我们需要在 src/main/resources/ META-INF/spring.factories 中配置信息,值得注意的是,这个文件要自己创建。

2019101710040_6.png

功能打包与配置依赖

好了,我们已经实现了一个简单的自动配置功能。那么,我们需要将这个项目打成 jar 包部署在我们的本地或者私服上。然后,就可以用了。

我们在另外一个项目中,配置 Maven 依赖。

2019101710040_7.png

测试,测试

2019101710040_8.png

运行起来,我们看下打印的发布者信息是什么?

我们在 application.properties 中配置一个信息。

#custom

custom.author = James

运行起来,我们看下打印的发布者信息是什么?

推荐一个架构学习交流群。交流学习群号:575745314 里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

一、源码分析

2019101710040_9.png

二、分布式架构

2019101710040_10.png

三、微服务

2019101710040_11.png

四、性能优化

2019101710040_12.png

五、Java工程化

2019101710040_13.png

来源:[]()

Spring Boot一个用于快速开发Java应用程序的框架,它基于Spring框架,并提供了自动配置和约定优于配置的原则。分页插件是在Spring Boot实现分页功能的一种方式,可以方便地对数据库查询结果进行分页处理。 要手写一个分页插件,你可以按照以下步骤进行: 1. 创建一个Page类,用于封装分页相关的信息,如当前页码、每页显示数量、总记录数等。 2. 在数据库查询方法中,根据传入的Page对象,使用limit语句限制查询结果的范围,实现分页功能。 3. 在业务层或控制层中,根据用户请求的页码和每页显示数量,创建Page对象,并将其传递给数据库查询方法。 4. 在前端页面中,显示分页导航栏和查询结果列表,并提供翻页功能。 下面是一个简单的示例代码,演示了如何手写一个基于MySQL数据库的分页插件: ```java // Page类 public class Page { private int pageNum; // 当前页码 private int pageSize; // 每页显示数量 private int total; // 总记录数 // 省略getter和setter方法 } // 数据库查询方法 public List<User> getUsers(Page page) { int offset = (page.getPageNum() - 1) * page.getPageSize(); String sql = "SELECT * FROM user LIMIT ?, ?"; return jdbcTemplate.query(sql, new Object[]{offset, page.getPageSize()}, new BeanPropertyRowMapper<>(User.class)); } // 业务层或控制层 public List<User> getUsers(int pageNum, int pageSize) { Page page = new Page(); page.setPageNum(pageNum); page.setPageSize(pageSize); page.setTotal(userDao.countUsers()); // 获取总记录数 return userService.getUsers(page); } // 前端页面 <!-- 分页导航栏 --> <div class="pagination"> <a href="?pageNum=1">首页</a> <a href="?pageNum=${page.pageNum-1}">上一页</a> <a href="?pageNum=${page.pageNum+1}">下一页</a> <a href="?pageNum=${page.totalPage}">尾页</a> </div> <!-- 查询结果列表 --> <table> <thead> <tr> <th>姓名</th> <th>年龄</th> </tr> </thead> <tbody> <c:forEach items="${users}" var="user"> <tr> <td>${user.name}</td> <td>${user.age}</td> </tr> </c:forEach> </tbody> </table> ``` 希望以上示例能帮助到你!如果有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值