已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结。
之前在网上找过不少关于springboot的教程,都是一些比较粗糙的文章,就连百度百科也是少的可怜,所以进度一直跟不上计划。下面根据我这几天的学习和摸索,谈谈我对spring和springboot的区别,以及很多业界人士说它的快速开发,到底是快在哪儿,方便在哪儿?首先我认为在项目的架构搭建方面变得极其利索,不再需要像之前一样整合ssh或ssm那样进行一大堆的配置文件,他只是通过一个application入口类来配置所有的配置项,包括spring的一些默认配置项;其次springboot它没有太多自己的特性,没有完全颠覆之前的开发模式,反而提供了更加便捷的方式来集成了原来的开发模式,只能说换了一种快速的方式来提高开发速度。
废话我也不多说了,也说不了,后面我会把我这几天的整合过程详细给大家总结下来,初次接触如有地方有误的,望及时指正。
pom文件中各项依赖的作用见代码注释。
先介绍一下在入口类中需要用到的常用注解:
@SpringBootApplication:这是一个组合注解,聚合了多个注解的功能,包含:排除自启动项、排除自启动项的beanname、扫描包和扫描类。【建议瞜一眼源码更好】
@EnableAutoConfiguration:这个注解是用来启动springboot中的自动配置项目,必须的加上,否则无法正常使用springboot默认配置的配置项目。
@ComponentScan :扫描controller层和service层中所有类上的注解(这个注解可以不加,因为组合注解@SpringBootApplication已经可以扫描)。
@MapperScan("com.zxz.mapper") :管理mybatis中所有mapper接口的代理对象。
@EnableTransactionManagement(proxyTargetClass = true):开启事务管理的注解。
因为我的项目最后是需要和mybatis整合的,所以在该入口类中必定有一些数据源、每层包扫描和注解扫描、管理mybatis中mapper接口的代理对象和事务管理器等一些必要的配置项。还有通过我上面的项目结构发现,mybatis的sql文件是放置在了resources文件下,所以还得通过配置映射到相应的xml文件中去等等,这些事情都需要借助该入口类来完成。
首先得配置好连接数据库的一些参数,之前我们是通常配置在某资源文件中,然后通过spring的配置文件进行加载到的,这里我们也需要将连接参数配置到SpringBoot规定的文件application.properties中,最后在入口类中通过注解加载即可。
application.properties配置内容:
在入口类中通过注解加载:
但是到这儿,可能很多哥们儿就有点说法了,现在大多数都是使用阿里的Druid数据源,因为性能好,但是在这里配置并没有指定数据源的具体类型,难道默认使用的是Druid,不是的,springboot还不至于这么完美,目前它仅仅支持dbcp、dbcp2、hikari三种数据库连接池。要是你就想要使用druid作为项目中的数据源,那么你就要费点儿力点开下面的代码,只需将它们复制到你的入口类中即可:
因为是和mybatis的整合,免不了mapper.xml的加载和映射,springboot提供了专门的方式来加载它们。
如果上面最基本的各项配置都差不多了,你就可以运行入口类中的伟大的main方法,看到如下界面没有报错信息则表示整合成功,各位尽量写个能访问数据库的业务逻辑来验证整合结果,这里因为时间问题我就不粘贴了:
好了,到这儿我也快收工了,今天就总结到这儿吧,下次继续给各位总结springboot整合mybatis的分页插件pageHelper、springboot的热部署和springboot的日志加载等,与君共勉。