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架構筆記

相關文章
相關標籤/搜索