首页 > 技术文章 > Spring Boot入门

yft-javaNotes 2019-04-01 15:55 原文

一、什么是Spring Boot 

  Spring 诞生时是 Java 企业版(Java Enterprise Edition,JEE,也称 J2EE)的轻量级代替品。无需开发重量级的 Enterprise JavaBean(EJB),Spring 为企业级Java 开发提供了一种相对简单的方法,通过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java Object,POJO)实现了 EJB 的功能。

  虽然 Spring 的组件代码是轻量级的,但它的配置却是重量级的。一开始,Spring 用 XML 配置,而且是很多 XML 配置。Spring 2.5 引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件的显式 XML 配置。Spring 3.0 引入了基于 Java 的配置,这是一种类型安全的可重构配置方式,可以代替 XML。所有这些配置都代表了开发时的损耗。因为在思考 Spring 特性配置和解决业务问题之间需要进行思维切换,所以写配置挤占了写应用程序逻辑的时间。和所有框架一样,Spring 实用,但与此同时它要求的回报也不少。

  除此之外,项目的依赖管理也是件吃力不讨好的事情。决定项目里要用哪些库就已经够让人头痛的了,你还要知道这些库的哪个版本和其他库不会有冲突,这难题实在太棘手。并且,依赖管理也是一种损耗,添加依赖不是写应用程序代码。一旦选错了依赖的版本,随之而来的不兼容问题毫无疑问会是生产力杀手。

  Spring Boot 让这一切成为了过去。

  Spring Boot 是 Spring 社区较新的一个项目。该项目的目的是帮助开发者更容易的创建基于 Spring 的应用程序和服务,让更多人的人更快的对 Spring 进行入门体验,为 Spring 生态系统提供了一种固定的、约定优于配置风格的框架。

  Spring Boot 具有如下特性:

  (1)为基于 Spring 的开发提供更快的入门体验

  (2)开箱即用,没有代码生成,也无需 XML 配置。同时也可以修改默认值来满足特定的需求。

  (3)提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。

  (4)Spring Boot 并不是对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方式。

二、Spring Boot入门案例

2.1 添加起步依赖

  创建Maven工程 springboot_demo(打包方式jar) 

  在pom.xml中添加如下依赖

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.0.RELEASE</version>
    </parent>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>

  我们会惊奇地发现,我们的工程自动添加了好多好多jar包

  

  而这些jar包正是我们做开发时需要导入的jar包。因为这些jar包被我们刚才引入的spring-boot-starter-web所引用了,所以我们引用spring-boot-starter-web后会自动把依赖传递过来。

  接下来简单探讨一下pom.xml

【父项目】

  跟进<artifactId>spring-boot-starter-parent</artifactId>,发现它的父项目是

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

 

2.2 创建引导类

  创建一个引导类Application 

@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

  我们直接执行这个引导类,会发现控制台出现的这个标识

  

【剖析@SpringBootApplication】

  @SpringBootApplication: Spring Boot应用标注在某个类上说明这个类是SpringBoot的主配置类,SpringBoot就应该运行这个类的main方法来启动SpringBoot应用;

  

  @SpringBootConfiguration:Spring Boot的配置类;标注在某个类上,表示这是一个Spring Boot的配置类。这个注解里面有@Configuration,用于定义一个配置类

  @EnableAutoConfiguration :开启自动配置功能;以前我们需要配置的东西,Spring Boot帮我们自动配置;@EnableAutoConfiguration告诉SpringBoot开启自动配置功能,这样自动配置才能生效;

  

    • @AutoConfigurationPackage:自动配置包,跟进这个类:

      

      @Import(AutoConfigurationPackages.Registrar.class):Spring的底层注解@Import,给容器中导入一个组件;导入的组件由AutoConfigurationPackages.Registrar.class将主配置类(@SpringBootApplication标注的类)的所在包及下面所有子包里面的所有组件扫描到Spring容器;通过打断点的方式,可以看出:

  @Import({AutoConfigurationImportSelector.class}):这个类告诉我们spring boot给容器中导入哪些组件。将所有需要导入的组件以全类名的方式返回;这些组件就会被添加到容器中;会给容器中导入非常多的自动配置类(xxxAutoConfiguration);就是给容器中导入这个场景需要的所有组件,并配置好这些组件。有了自动配置类,免去了我们手动编写配置注入功能组件等的工作;

  

2.3 编写Controller

  我们现在开始使用spring MVC框架,实现json数据的输出。如果按照我们原来的做法,需要在web.xml中添加一个DispatcherServlet的配置,还需要添加一个spring的配置文件(springmvc.xml)。

  但是我们用SpringBoot,这一切都省了。我们直接写Controller类

@RestController
public class HelloWordController {
    @RequestMapping("/info")
    public String info() {
        return "HelloWorld";
    }
}

  我们运行启动类来运行程序

  在浏览器地址栏输入 http://localhost:8080/info 即可看到运行结果

【注意】

  spring boot启动类和自定义controller如果不在相同的目录,controller会扫描不到。

  解决办法:

  1.将要用的组建放在启动类包下(不规范)
  2.在启动类填加注解@ComponentScan("包名") 

2.4 简化部署

  在pom.xml中添加

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

  执行package命令,将项目打包成jar包

  

  在命令行中直接使用java -jar进行执行

 

  

 

2.2 变更JDK版本

  我们发现默认情况下工程的JDK版本是1.6 ,而我们通常用使用1.7的版本,所以我们需要在pom.xml中添加以下配置

  <properties>   
    <java.version>1.7</java.version>
  </properties>

  添加后更新工程,会发现版本已经变更为1.7

2.5 修改tomcat启动端口

  在src/main/resources下创建application.properties

server.port=8088

  重新运行引导类。地址栏输入http://localhost:8088/info

2.6 读取配置文件信息

  在src/main/resources下的application.properties 增加配置

url=http://www.baidu.com

   我要在类中读取这个配置信息,修改HelloWorldController  

@RestController
public class HelloWordController {
    @Autowired
    private Environment env;

    @RequestMapping("/info")
    public String info() {
        return "HelloWorld" + env.getProperty("url");
    }
}

2.7 热部署

  我们在开发中反复修改类、页面等资源,每次修改后都是需要重新启动才生效,这样每次启动都很麻烦,浪费了大量的时间,能不能在我修改代码后不重启就能生效呢?可以,在pom.xml中添加如下配置就可以实现这样的功能,我们称之为热部署。

    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-devtools</artifactId>  
    </dependency>  

三、Spring Boot与ActiveMQ整合

3.1 使用内嵌服务

  (1)在pom.xml中引入ActiveMQ起步依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-activemq</artifactId>
</dependency>

  (2)创建消息生产者

@RestController
public class QueueController {
    @Autowired
    private JmsMessagingTemplate jmsMessagingTemplate;

    @RequestMapping("/send")
    public void send(String text) {
        jmsMessagingTemplate.convertAndSend("springboot-text", text);
    }
}

  (3)创建消息消费者

@Component
public class Consumer {

    @JmsListener(destination = "springboot-text")
    public void readMessage(String text) {
        System.out.println("接收到消息:" + text);
    }
}

  测试:启动服务后,在浏览器执行

  http://localhost:8088/send.do?text=aaaaa

  即可看到控制台输出消息提示。Spring Boot内置了ActiveMQ的服务,所以我们不用单独启动也可以执行应用程序。

3.2 使用外部服务

  在src/main/resources下的application.properties增加配置, 指定ActiveMQ的地址

spring.activemq.broker-url=tcp://192.168.25.137:61616

  运行后,会在activeMQ中看到发送的queue

  

3.3 发送Map信息

  (1)修改QueueController.java

    @RequestMapping("/sendmap")
    public void sendMap() {
        Map map = new HashMap();
        map.put("mobile", "13533277289");
        map.put("content", "发送map信息");
        jmsMessagingTemplate.convertAndSend("springboot-map", map);
    }

  (2)修改Consumer.java

    @JmsListener(destination = "springboot-map")
    public void readMap(Map map) {
        System.out.println(map);
    }

 

推荐阅读