SpringBoot學習總結——HelloWorld程序分析

最近開始學ssm框架才知道了框架的方便之處,然後有人告訴我springboot是ssm框架的升級版,所以準備學一下,在這裏記錄一下學習的歷程和碰到的坑

使用idea可以快速創建springboot項目選擇我們需要的模塊;嚮導會聯網創建Spring Boot項目;在這裏插入圖片描述先看一下pom文件中爲我們自動生成的依賴

父項目

在這裏插入圖片描述ctrl點擊spring-boot-starter-parent

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

點進去之後可以看到這個父項目,他來真正管理Spring Boot應用裏面的所有依賴版本;以後我們導入依賴默認是不需要寫版本(沒有在dependencies裏面管理的依賴自然需要聲明版本號)

啓動器

在這裏插入圖片描述對於spring-boot-starter-web
spring-boot-starter:spring-boot場景啓動器;幫我們導入了web模塊正常運行所依賴的組件;
Spring Boot將所有的功能場景都抽取出來,做成一個個的starters(啓動器),只需要在項目裏面引入這些starter相關場景的所有依賴都會導入進來。要用什麼功能就導入什麼場景的啓動器

接下來看一下生成的代碼

默認生成的Spring Boot項目;

  • 主程序已經生成好了,我們只需要我們自己的邏輯
  • resources文件夾中目錄結構
    • static:保存所有的靜態資源; js css images;
    • templates:保存所有的模板頁面;(Spring Boot默認jar包使用嵌入式的Tomcat,默認不支持JSP頁面【現在流行前後端分離,JSP正在逐漸被淘汰】);可以使用模板引擎(freemarker、thymeleaf);
    • application.properties:Spring Boot應用的配置文件;可以修改一些默認設置(例如tomcat的端口號);

主程序類,主入口類

在生成的項目中,會自動爲我們生成主程序類

/**
 *  @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應用;

ctrl點擊@SpringBootApplication進入可以看到詳細的註解

@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的配置類

    在這個註解的底層其實標註了@Configuration註解,並對其進行了增強

    @Configuration註解標註在一個配置類上,來代替ssm框架中的配置文
    件(在@Configuration註解底層標註了@Component註解,表明這個配置 類也是容器中的一個組件,交給容器管理)

  • @EnableAutoConfiguration:開啓自動配置功能
    添加了這個註解,會告訴SpringBoot開啓自動配置功能;這樣自動配置才能生效,以前我們需要配置的東西,Spring Boot會幫我們自動配置

    在這個註解底層有@AutoConfigurationPackage註解 @AutoConfigurationPackage註解底層會調用 @Import(AutoConfigurationPackages.Registrar.class)給容器中導入一個組件;

    導入的組件由AutoConfigurationPackages.Registrar.class將主配置類(@SpringBootApplication標註的類)的所在包及下面所有子包裏面的所有組件掃描到Spring容器(如果此時把Controller層放到主配置類所在包之外,則會報404錯誤)

    @EnableAutoConfiguration註解底層還有@Import(AutoConfigurationImportSelector.class)註解會給容器中導入非常多的自動配置類(xxxAutoConfiguration),就是給容器中導入這個場景需要的所有組件,並配置好這些組件

    有了@EnableAutoConfiguration自動配置類,免去了我們手動編寫配置注入功能組件等的工作

Controller

控制器則是和ssm中一樣,需要我們自己編寫

// @ResponseBody//這個類的所有方法返回的數據直接寫給瀏覽器(如果對象是轉爲json數據)
// @Controller
@RestController
public class HelloController {

    @RequestMapping("/hello")
    public String hello() {
        return "hello world quick!";
    }
}
  • @ResponseBody:這個類的所有方法返回的數據直接寫給瀏覽器(如果對象是轉爲json數據)
  • @Controller:標註這是一個控制器
  • @RestController:作用相當於@ResponseBody+@Controller
  • @RequestMapping:用於映射url到控制器類或一個特定的處理程序方法。可用於類或方法上。用於方法上,表示方法的請求路徑,用於類上,表示類中的所有響應請求的方法都是以該地址作爲父路徑。

這樣的話,springboot的第一個hello world代碼就運行成功了
在這裏插入圖片描述
小結:相對於ssm框架來說,springboot採用了自動配置,省去了對配置文件的編寫,減少了代碼量和錯誤量,對於程序員可以說是非常友好了,由此可以看出框架的美還需要我們慢慢去體會

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章