SpringBoot(一):Spring Boot入门

一、简介

Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。

  • 简化了Spring应用开发的一个框架
  • 整个Spring技术栈的一个整合
  • J2EE开发的一站式解决方案

优点:

  • 快速创建独立运行的Spring项目和主流框架集成
  • 使用嵌入式的Servlet容器,应用无需打成WAR包
  • starters自动依赖与版本控制
  • 大量的自动配置,简化开发,也可以修改默认值
  • 无需配置XML,无代码生成,开箱即用

二、入门程序(SpringBoot的HelloWorld)

功能描述:浏览器发送hello请求,服务器接收请求并处理,响应Hello World字符串。

1.创建一个Maven工程
在这里插入图片描述
通过IDEA创建一个Maven工程。
创建成功的界面
在这里插入图片描述

2.导入SpringBoot的相关的依赖
在pom.xml文件中加入springboot的依赖。
在这里插入图片描述
内容如下:

<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.编写一个主程序:启动SpringBoot应用

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

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

4.编写相关的controller

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

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

5.运行程序,并测试
在这里插入图片描述
我们可以在浏览器中访问到。证明成功了。

6.简化部署的部分
在pom文件中加入插件,可以使应用打包成一个可以执行的jar包。
在这里插入图片描述
代码如下:

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

打包操作:
在这里插入图片描述
点击Run Maven Build可以打包。
可以在target文件下看到打包的结果
在这里插入图片描述

三、入门程序探究

1.父项目

我们在pom文件中引入了父项目

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.9.RELEASE</version>
</parent>

spring-boot-start-parent的父项目是:

<parent>
	  <groupId>org.springframework.boot</groupId>
	  <artifactId>spring-boot-dependencies</artifactId>
	  <version>1.5.9.RELEASE</version>
	  <relativePath>../../spring-boot-dependencies</relativePath>
</parent>

用来管理SpringBoot应用中的所有依赖的版本,基本包含了我们平常使用大部分依赖。所以我们可以引入依赖不用写版本号,如果不在里面的需要写版本号。

Spring Boot的版本仲裁中心。

2.启动器

我们在pom文件中引入了web的启动器

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

spring-boot-starter:spring-boot场景启动器;帮我们导入了web模块正常运行所依赖的组件;

Spring Boot将所有的功能场景都抽取出来,做成一个个的starters(启动器),只需要在项目里面引入这些starter相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器

3.注解
在这里插入图片描述
我们来了解一下关于@SpringBootApplication的注解。
在这里插入图片描述

追踪源码,我们可以发现SpringBootApplication注解中有@SpringBootConfiguration和@EnableAutoConfiguration两个关键注解。

(1)@SpringBootConfiguration:Spring Boot的配置类,表示是一个配置类(@Configuration)。

(2)@EnableAutoConfiguration:开启自动配置功能。

我们深入@EnableAutoConfiguration:
在这里插入图片描述
(1)@AutoConfigurationPackage: 自动配置包,将主配置类(@SpringBootApplication标注的类)的所在包及下面所有子包里面的所有组件扫描到Spring容器。(相当于原来开启包扫描)
(2)@Import(EnableAutoConfigurationImportSelector.class):Spring Boot在启动的时候从spring-boot-autoconfigurejar包路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;以前我们需要自己配置的东西,自动配置类都帮我们(例如SpringMVC中的视图解析器之类的);

四、使用Spring Initializer快速创建Spring Boot项目

IDE都支持使用Spring的项目创建向导快速创建一个Spring Boot项目;
在这里插入图片描述
在这里插入图片描述
最后生成项目:
在这里插入图片描述
选择我们需要的模块;向导会联网创建Spring Boot项目;

默认生成的Spring Boot项目;
(1)主程序已经生成好了,我们只需要我们自己的逻辑

(2)resources文件夹中目录结构

  • static:保存所有的静态资源,js css images;
  • templates:保存所有的模板页面;(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页面);可以使用模板引擎(freemarker、thymeleaf);
  • application.properties:Spring Boot应用的配置文件;可以修改一些默认设置;

猜你喜欢

转载自blog.csdn.net/jdfk423/article/details/82845762