码迷,mamicode.com
首页 > 编程语言 > 详细

Spring Boot 入门

时间:2019-01-12 14:20:25      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:区分   depend   目标   into   需要   ges   interface   引擎   解决方案   

一、Spring Boot 入门

1、Spring Boot 简介

简化Spring应用开发的一个框架;

整个Spring技术栈的一个大整合;

J2EE开发的一站式解决方案;

2、微服务

2014,martin fowler

微服务:架构风格(服务微化)

一个应用应该是一组小型服务;可以通过HTTP的方式进行互通;

单体应用:ALL IN ONE

微服务:每一个功能元素最终都是一个可独立替换和独立升级的软件单元;

详细参照微服务文档

 

3、环境准备

http://www.gulixueyuan.com/ 谷粒学院

环境约束

–jdk1.8:Spring Boot 推荐jdk1.7及以上;java version "1.8.0_112"

–maven3.x:maven 3.3以上版本;Apache Maven 3.3.9

–IntelliJIDEA2017:IntelliJ IDEA 2017.2.2 x64、STS

–SpringBoot 1.5.9.RELEASE:1.5.9;

统一环境;

 

1、MAVEN设置;

给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>

2、IDEA设置

整合maven进来;

技术分享图片

 

技术分享图片

4、Spring Boot HelloWorld

一个功能:

浏览器发送hello请求,服务器接受请求并处理,响应Hello World字符串;

 

1、创建一个maven工程;(jar)

2、导入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>

3、编写一个主程序;启动Spring Boot应用

?
/**
* @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用
*/
@SpringBootApplication
public class HelloWorldMainApplication {
?
   public static void main(String[] args) {
?
       // Spring应用启动起来
       SpringApplication.run(HelloWorldMainApplication.class,args);
  }
}

4、编写相关的Controller、Service


@Controller
public class HelloController {
?
   @ResponseBody
   @RequestMapping("/hello")
   public String hello(){
       return "Hello World!";
  }
}
?

 

5、运行主程序测试

6、简化部署


<!-- 这个插件,可以将应用打包成一个可执行的jar包;-->
   <build>
       <plugins>
           <plugin>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-maven-plugin</artifactId>
           </plugin>
       </plugins>
   </build>

将这个应用打成jar包,直接使用java -jar的命令进行执行;

5、Hello World探究

1、POM文件

1、父项目


<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里面管理的依赖自然需要声明版本号)

2、启动器


<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相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器

 

2、主程序类,主入口类


/**
* @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用
*/
@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:配置类上来标注这个注解;