简化Spring
应用开发的一个框架、整个Spring
技术栈的一个大整合;
J2EE
开发的一站式解决方案;
优点:
快速创建独立运行的Spring
项目以及与主流框架集成;
使用嵌入式的Servlet
容器,应用无需打成WAR
包;
starters
自动依赖与版本控制;
大量的自动配置,简化开发,也可修改默认值;
无需配置XML
,无代码生成,开箱即用;
准生产环境的运行时应用监控;
与云计算的天然集成;
martin fowler论文提出。
微服务:架构风格(服务微化)
一个应用应该是一组小型服务;可以通过HTTP
的方式进行互通;
单体应用:ALL IN ONE
微服务:每一个功能元素最终都是一个可独立替换和独立升级的软件单元;
给maven
的settings.xml
配置文件的profiles
标签添加下面的代码:
<profile> <id>jdk-1.8</id> <activation> <activeByDefault>true</activeByDefault> <jdk>1.8</jdk> </activation> <properties> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion> </properties> </profile>
表示maven
使用jdk1.8
。
实现功能:
浏览器发送
hello
请求,服务器接受请求并处理,响应Hello Springboot!
字符串;即浏览器输入localhost:8080/hello
可以看到浏览器显示Hello SpringBoot!
字符串;
① 创建一个maven
工程(jar
);
② 导入spring boot
相关的依赖;
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring‐boot‐starter‐parent</artifactId> <version>1.5.9.RELEASE</version> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring‐boot‐starter‐web</artifactId> </dependency> </dependencies>
③ 编写一个主程序,启动Spring Boot
应用
/** * @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用 */ @SpringBootApplication public class HelloWorldMainApplication { public static void main(String[] args) { // Spring应用启动起来 SpringApplication.run(HelloWorldMainApplication.class, args); } }
④ 编写相关的Controller
@Controller public class HelloController { @ResponseBody @RequestMapping("/hello") public String hello(){ return "Hello SpringBoot!"; } }
⑤ 运行主程序测试
⑥简化部署
将这个应用打成jar
包,直接使用java-jar
的命令进行执行;
<!-- 这个插件,可以将应用打包成一个可执行的jar包;--> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
结果:
父项目
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> </parent>
他的父项目:
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>1.5.9.RELEASE</version> <relativePath>../../spring-boot-dependencies</relativePath> </parent>
他来真正管理Spring Boot
应用里面的所有依赖版本;
也就是Spring Boot
的版本仲裁中心;
以后我们导入依赖默认是不需要写版本;(没有在dependencies
里面管理的依赖自然需要声明版本号)
启动器:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
spring-boot-starter-web:
spring-boot-starter
:spring-boot
场景启动器;帮我们导入了web
模块正常运行所依赖的组件;
Spring Boot
将所有的功能场景都抽取出来,做成一个个的starters
(启动器),只需要在项目里面引入这些starter
相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器。
@SpringBootApplication public class HelloWorldMainApplication { public static void main(String[] args) { // Spring应用启动起来 SpringApplication.run(HelloWorldMainApplication.class,args); } }
① @SpringBootApplication
: Spring Boot
应用标注在某个类上说明这个类是SpringBoot
的主配置类,SpringBoot
就应该运行这个类的main
方法来启动SpringBoot
应用;这是一个组合注解。
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @SpringBootConfiguration @EnableAutoConfiguration @ComponentScan( excludeFilters = {@Filter( type = FilterType.CUSTOM, classes = {TypeExcludeFilter.class} ), @Filter( type = FilterType.CUSTOM, classes = {AutoConfigurationExcludeFilter.class} )} ) public @interface SpringBootApplication { ... }
下面看里面的每个注解含义:
@SpringBootConfiguration
: Spring Boot
的配置类,标注在某个类上,表示这是一个Spring Boot
的配置类,里面包含这个@Configuration
(也就是Spring
里面的配置类);
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Configuration public @interface SpringBootConfiguration { }
配置类 —–> 配置文件;配置类也是容器中的一个组件:@Component
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Component //组件注解 public @interface Configuration { @AliasFor( annotation = Component.class ) String value() default ""; }
② @EnableAutoConfiguration
:开启自动配置功能;
以前我们需要配置的东西,Spring Boot
帮我们自动配置;@EnableAutoConfiguration
告诉SpringBoot
开启自动配置功能,这样自动配置才能生效;
@AutoConfigurationPackage @Import({AutoConfigurationImportSelector.class}) public @interface EnableAutoConfiguration { }
@AutoConfigurationPackage
:自动配置包
@Import(AutoConfigurationPackages.Registrar.class)
:Spring
的底层注解@Import
,给容器中导入一个组件;导入的组件由AutoConfigurationPackages.Registrar.class
指定。 也就是: 将主配置类(@SpringBootApplication
标注的类)的所在包及下面所有子包里面的所有组件扫描到Spring容器;,所以如果上面的controller
如果不是在主配置类所在的包(或者子包)下,就不能扫描到。
@Import(EnableAutoConfigurationImportSelector.class)
: 给容器中导入组件(不在同一个包下面的)EnableAutoConfigurationImportSelector
:导入哪些组件的选择器;将所有需要导入的组件以全类名的方式返回,这些组件就会被添加到容器中;会给容器中导入非常多的自动配置类(xxxAutoConfiguration
);就是给容器中导入这个场景需要的所有组件,并配置好这些组件;
有了自动配置类,免去了我们手动编写配置注入功能组件等的工作; 里面的getCandidateConfigurations
调用了下面的一个方法: SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader)
Spring Boot在启动的时候从类路径下的META-INF/spring.factories
中获取EnableAutoConfiguration
指定的值,将这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;以前我们需要自己配置的东西,自动配置类都帮我们;
J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-xxx.RELEASE.jar
;
IDE都支持使用Spring的项目创建向导快速创建一个Spring Boot项目。选择我们需要的模块,向导会联网创建Spring Boot项目,默认生成的Spring Boot项目; 主程序生成好了,我们只需要我们自己的逻辑。
resources
: 文件夹中目录结构
static
:保存所有的静态资源; js css images
;
templates
:保存所有的模板页面;(Spring Boot默认jar
包使用嵌入式的Tomcat
,默认不支持JSP
页 面);可以使用模板引擎(freemarker
、thymeleaf
);
application.properties
:Spring Boot应用的配置文件,可以修改一些默认设置;
结构目录:
简单Controller
,注意@RestController
注解。
package com.zxin.springboot.controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.bind.annotation.RestController; //@ResponseBody // 这个类的所有方法返回的数据直接写给浏览器(如果是对象 -> 转成json) //@Controller @RestController // 这个注解的作用和上面两个一起的作用相同 (就是 ResponseBody和Controller的合体) public class HelloController { @ResponseBody //如果每个类都需要写,麻烦 @RequestMapping("/hello") public String hello(){ return "hello quick SpringBoot!"; } }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。