spring boot入门,看这篇文章就够了

1、SpringBoot入门

一、基本介绍

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

优势:css

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

二、微服务

  • martin fowler论文提出。
  • 微服务:架构风格(服务微化)
  • 一个应用应该是一组小型服务;能够经过HTTP的方式进行互通;
  • 单体应用:ALL IN ONE
  • 微服务:每个功能元素最终都是一个可独立替换和独立升级的软件单元;

三、MAVEN设置

mavensettings.xml配置文件的profiles标签添加下面的代码:html

<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.8java

四、Spring Boot HelloWorld

实现功能:web

浏览器发送 hello请求,服务器接受请求并处理,响应 Hello Springboot! 字符串;即浏览器输入 localhost:8080/hello能够看到浏览器显示 Hello SpringBoot!字符串;

① 建立一个maven工程(jar);spring

② 导入spring boot相关的依赖;json

<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);
    }
}复制代码

④ 编写相关的Controllerspringboot

@Controller
public class HelloController {

    @ResponseBody
    @RequestMapping("/hello")
    public String hello(){
        return "Hello SpringBoot!";
    }
}复制代码

⑤ 运行主程序测试bash

⑥简化部署服务器

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

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

结果:

五、Hello World探究

(1)、Pom.xml文件

父项目

<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-starterspring-boot场景启动器;帮咱们导入了web模块正常运行所依赖的组件;

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

(2)、主程序类,主入口类

@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


六、使用Spring Initializer快速建立Spring Boot项目

IDE都支持使用Spring的项目建立向导快速建立一个Spring Boot项目。选择咱们须要的模块,向导会联网建立Spring Boot项目,默认生成的Spring Boot项目; 主程序生成好了,咱们只须要咱们本身的逻辑。

  • resources : 文件夹中目录结构
    • static:保存全部的静态资源; js css images
    • templates:保存全部的模板页面;(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页 面);可使用模板引擎(freemarkerthymeleaf);
    • 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!";
    }
}复制代码

原文:Java架构笔记

相关文章
相关标签/搜索