【狂神说Java】SpringBoot笔记
Spring Boot01:Hello,World!
1、什么是Spring
Spring是⼀个开源框架,2003 年兴起的⼀个轻量级的Java 开发框架,作者:Rod Johnson 。
Spring是为了解决企业级应⽤开发的复杂性⽽创建的,简化开发。
2、Spring是如何简化Java开发的
为了降低Java开发的复杂性,Spring采⽤了以下4种关键策略:
1、基于POJO的轻量级和最⼩侵⼊性编程,所有东西都是bean;
2、通过IOC,依赖注⼊(DI)和⾯向接⼝实现松耦合;
3、基于切⾯(AOP)和惯例进⾏声明式编程;
4、通过切⾯和模版减少样式代码,RedisTemplate,xxxTemplate;
3、什么是SpringBoot
学过javaweb的同学就知道,开发⼀个web应⽤,从最初开始接触Servlet结合Tomcat, 跑出⼀个Hello Wolrld程序,是要经历特别多的步骤;后来就⽤了框架Struts,再后来是SpringMVC,到了现在的SpringBoot,过⼀两年⼜会有其他web框架出现;你们有经历过框架不断的演进,然后⾃⼰开发项⽬所有的技术也在不断的变化、改造吗?建议都可以去经历⼀遍;
⾔归正传,什么是SpringBoot呢,就是⼀个javaweb的开发框架,和SpringMVC类似,对⽐其他javaweb框架的好处,官⽅说是简化开发,约定⼤于配置, you can “just run”,能迅速的开发web应⽤,⼏⾏代码开发⼀个http接⼝。
所有的技术框架的发展似乎都遵循了⼀条主线规律:从⼀个复杂应⽤场景 衍⽣ ⼀种规范框架,⼈们只需要进⾏各种配置⽽不需要⾃⼰去实现它,这时候强⼤的配置功能成了优点;发展到⼀定程度之后,⼈们根据实际⽣产应⽤情况,选取其中实⽤功能和设计精华,重构出⼀些轻量级的框架;之后为了提⾼开发效率,嫌弃原先的各类配置过于⿇烦,于是开始提倡“约定⼤于配置”,进⽽衍⽣出⼀些⼀站式的解决⽅案。
是的这就是Java企业级应⽤->J2EE->spring->springboot的过程。
随着 Spring 不断的发展,涉及的领域越来越多,项⽬整合开发需要配合各种各样的⽂件,慢慢变得不那么易⽤简单,违背了最初的理念,甚⾄⼈称配置地狱。Spring Boot 正是在这样的⼀个背景下被抽象出来的开发框架,⽬的为了让⼤家更容易的使⽤ Spring 、更容易的集成各种常⽤的中间件、开源软件;
Spring Boot 基于 Spring 开发,Spirng Boot 本⾝并不提供 Spring 框架的核⼼特性以及扩展功能,只是⽤于快速、敏捷地开发新⼀代基于 Spring 框架的应⽤程序。也就是说,它并不是⽤来替代 Spring 的解决⽅案,⽽是和 Spring 框架紧密结合⽤于提升 Spring 开发者体验的⼯具。Spring Boot 以约定⼤于配置的核⼼思想,默认帮我们进⾏了很多设置,多数 Spring Boot 应⽤只需要很少的 Spring 配置。同时它集成了⼤量常⽤的第三⽅库配置(例如 Redis、MongoDB、Jpa、RabbitMQ、Quartz 等等),Spring Boot 应⽤中这些第三⽅库⼏乎可以零配置的开箱即⽤。
简单来说就是SpringBoot其实不是什么新的框架,它默认配置了很多框架的使⽤⽅式,就像maven整合了所有的jar包,spring boot整合了所有的框架 。
Spring Boot 出⽣名门,从⼀开始就站在⼀个⽐较⾼的起点,⼜经过这⼏年的发展,⽣态⾜够完善,Spring Boot 已经当之⽆愧成为 Java 领域最热门的技术。
Spring Boot的主要优点:
为所有Spring开发者更快的⼊门
开箱即⽤,提供各种默认配置来简化项⽬配置
内嵌式容器简化Web项⽬
没有冗余代码⽣成和XML配置的要求
真的很爽,我们快速去体验开发个接⼝的感觉吧!
4、准备⼯作
我们将学习如何快速的创建⼀个Spring Boot应⽤,并且实现⼀个简单的Http请求处理。通过这个例⼦对Spring Boot有⼀个初步的了解,并体验其结构简单、开发快速的特性。
我的环境准备:
java version “1.8”
Maven-3.6.1
SpringBoot 2.x 最新版
开发⼯具:
IDEA
5、创建基础项⽬说明
Spring官⽅提供了⾮常⽅便的⼯具让我们快速构建应⽤
**项⽬创建⽅式⼀:**使⽤Spring Initializr 的 Web页⾯创建项⽬
2、填写项⽬信息
3、点击”Generate Project“按钮⽣成项⽬;下载此项⽬
4、解压项⽬包,并⽤IDEA以Maven项⽬导⼊,⼀路下⼀步即可,直到项⽬导⼊完毕。
5、如果是第⼀次使⽤,可能速度会⽐较慢,包⽐较多、需要耐⼼等待⼀切就绪。
**项⽬创建⽅式⼆:**使⽤ IDEA 直接创建项⽬
1、创建⼀个新项⽬
2、选择spring initalizr , 可以看到默认就是去官⽹的快速构建⼯具那⾥实现
3、填写项⽬信息
4、选择初始化的组件(初学勾选 Web 即可)
5、填写项⽬路径
6、等待项⽬构建成功
项⽬结构分析:
通过上⾯步骤完成了基础项⽬的创建。就会⾃动⽣成以下⽂件。
1、程序的主启动类
2、⼀个 application.properties 配置⽂件
3、⼀个 测试类
4、⼀个 l
6、l 分析
打开l,看看Spring Boot项⽬的依赖:
<!-- ⽗依赖 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/>
</parent>
<dependencies>
<!-- web场景启动器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- springboot单元测试 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
spring ioc注解<!-- 剔除依赖 -->
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<!-- 打包插件 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
7、编写⼀个http接⼝
1、在主程序的同级⽬录下,新建⼀个controller包,⼀定要在同级⽬录下,否则识别不到
2、在包中新建⼀个HelloController类
@RestController
public class HelloController {
@RequestMapping("/hello")
public String hello(){
return"Hello World";
}
}
3、编写完毕后,从主程序启动项⽬,浏览器发起请求,看页⾯返回;控制台输出了 Tomcat 访问的端⼝号!
简单⼏步,就完成了⼀个web接⼝的开发,SpringBoot就是这么简单。所以我们常⽤它来建⽴我们的微服务项⽬!
8、将项⽬打成jar包,点击 maven的 package
<!--
在⼯作中,很多情况下我们打包是不想执⾏测试⽤例的
可能是测试⽤例不完事,或是测试⽤例会影响数据库数据
跳过测试⽤例执
-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<!--跳过项⽬运⾏测试⽤例-->
<skipTests>true</skipTests>
</configuration>
</plugin>
如果打包成功,则会在target⽬录下⽣成⼀个 jar 包
打成了jar包后,就可以在任何地⽅运⾏了!
Spring Boot02:运⾏原理初探
1、l
1.1、⽗依赖
其中它主要是依赖⼀个⽗项⽬,主要是管理项⽬的资源过滤及插件!
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/><!-- lookup parent from repository -->
</parent>
点进去,发现还有⼀个⽗依赖
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/><!-- lookup parent from repository -->
</parent>
这⾥才是真正管理SpringBoot应⽤⾥⾯所有依赖版本的地⽅,SpringBoot的版本控制中⼼;
以后我们导⼊依赖默认是不需要写版本;但是如果导⼊的包没有在依赖中管理着就需要⼿动配置版本了;
1.2、启动器 spring-boot-starter
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
springboot-boot-starter-xxx:就是spring-boot的场景启动器
spring-boot-starter-web:帮我们导⼊了web模块正常运⾏所依赖的组件;
SpringBoot将所有的功能场景都抽取出来,做成⼀个个的starter (启动器),只需要在项⽬中引⼊这些starter即可,所有相关的依赖都会导⼊进来 , 我们要⽤什么功能就导⼊什么样的场景启动器即可 ;我们未来也可以⾃⼰⾃定义 starter;
2、主启动类
2.1、默认的主启动类
//@SpringBootApplication 来标注⼀个主程序类
//说明这是⼀个Spring Boot应⽤
@SpringBootApplication
public class SpringbootApplication {
public static void main(String[] args){
//以为是启动了⼀个⽅法,没想到启动了⼀个服务
SpringApplication.run(SpringbootApplication.class, args);
}
}
但是**⼀个简单的启动类并不简单!**我们来分析⼀下这些注解都⼲了什么
2.2、@SpringBootApplication
作⽤:标注在某个类上说明这个类是SpringBoot的主配置类 , SpringBoot就应该运⾏这个类的main⽅法来启动SpringBoot应⽤;
进⼊这个注解:可以看到上⾯还有很多其他注解!
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(
excludeFilters ={@Filter(
type = FilterType.CUSTOM,
classes ={TypeExcludeFilter.class}
),@Filter(
type = FilterType.CUSTOM,
classes ={AutoConfigurationExcludeFilter.class}
)}
)
public@interface SpringBootApplication {
// ......
}
2.3、@ComponentScan
这个注解在Spring中很重要 ,它对应XML配置中的元素。
作⽤:⾃动扫描并加载符合条件的组件或者bean , 将这个bean定义加载到IOC容器中
2.4、@SpringBootConfiguration
作⽤:SpringBoot的配置类 ,标注在某个类上 , 表⽰这是⼀个SpringBoot的配置类;
我们继续进去这个注解查看
// 点进去得到下⾯的 @Component
@Configuration
public@interface SpringBootConfiguration {}
@Component
public@interface Configuration {}
这⾥的 @Configuration,说明这是⼀个配置类 ,配置类就是对应Spring的xml 配置⽂件;
⾥⾯的 @Component 这就说明,启动类本⾝也是Spring中的⼀个组件⽽已,负责启动应⽤!
我们回到 SpringBootApplication 注解中继续看。
2.5、@EnableAutoConfiguration
@EnableAutoConfiguration :开启⾃动配置功能
以前我们需要⾃⼰配置的东西,⽽现在SpringBoot可以⾃动帮我们配置 ;@EnableAutoConfiguration告诉SpringBoot开启⾃动配置功能,这样⾃动配置才能⽣效;
点进注解接续查看:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。