1. 程式人生 > >springboot入門之基礎篇(一)

springboot入門之基礎篇(一)

一、前言

Spring Boot 是由 Pivotal 團隊提供的全新框架,其設計目的是用來簡化新 Spring 應用的初始搭建以及開發過程。該框架使用了特定的方式來進行配置,從而使開發人員不再需要定義樣板化的配置。

本系列以快速入門為主,可當作工具小手冊閱讀

二、環境搭建

建立一個 maven 工程,目錄結構如下圖:

image

2.1 新增依賴

建立 maven 工程,在 pom.xml 檔案中新增如下依賴:

<!-- 定義公共資源版本 -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId
>
spring-boot-starter-parent</artifactId> <version>1.5.6.RELEASE</version> <relativePath/> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding
>
<java.version>1.8</java.version> </properties> <dependencies> <!-- 上邊引入 parent,因此 下邊無需指定版本 --> <!-- 包含 mvc,aop 等jar資源 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId
>
</dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>

2.2 建立目錄和配置檔案

建立 src/main/resources 原始檔目錄,並在該目錄下建立 application.properties 檔案、static 和 templates 的資料夾。

application.properties:用於配置專案執行所需的配置資料。

static:用於存放靜態資源,如:css、js、圖片等。

templates:用於存放模板檔案。

目錄結構如下:

image

2.3 建立啟動類

在 com.light.springboot 包下建立啟動類,如下:

/** 該註解指定專案為springboot,由此類當作程式入口 自動裝配 web 依賴的環境**/
@SpringBootApplication
public class SpringbootApplication {

    publicstaticvoidmain(String[] args) {
        SpringApplication.run(SpringbootApplication.class, args);
    }
}

2.4 案例演示

建立 com.light.springboot.controller 包,在該包下建立一個 Controller 類,如下:

@RestController
public class TestController {

    @GetMapping("/helloworld")
    public String helloworld() {
        return "helloworld";
    }
}

在 SpringbootApplication 檔案中右鍵 Run as -> Java Application。當看到 “Tomcat started on port(s): 8080 (http)” 字樣說明啟動成功。

image

讀者可以使用 STS 開發工具,裡邊集成了外掛,可以直接建立 Spingboot 專案,它會自動生成必要的目錄結構。

三、熱部署

當我們修改檔案和建立檔案時,都需要重新啟動專案。這樣頻繁的操作很浪費時間,配置熱部署可以讓專案自動載入變化的檔案,省去的手動操作。

在 pom.xml 檔案中新增如下配置:

<!-- 熱部署 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
    <optional>true</optional>
    <scope>true</scope>
</dependency>
<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <!-- 沒有該配置,devtools 不生效 -->
                <fork>true</fork>
            </configuration>
        </plugin>
    </plugins>
</build>

配置好 pom.xml 檔案後,我們啟動專案,隨便建立/修改一個檔案並儲存,會發現控制檯列印 springboot 重新載入檔案的資訊。

演示圖如下:

image

四、多環境切換

application.properties 是 springboot 在執行中所需要的配置資訊。

當我們在開發階段,使用自己的機器開發,測試的時候需要用的測試伺服器測試,上線時使用正式環境的伺服器。

這三種環境需要的配置資訊都不一樣,當我們切換環境執行專案時,需要手動的修改多出配置資訊,非常容易出錯。

為了解決上述問題,springboot 提供多環境配置的機制,讓開發者非常容易的根據需求而切換不同的配置環境。

在 src/main/resources 目錄下建立三個配置檔案:

application-dev.properties:用於開發環境
application-test.properties:用於測試環境
application-prod.properties:用於生產環境

我們可以在這個三個配置檔案中設定不同的資訊,application.properties 配置公共的資訊。

在 application.properties 中配置:

spring.profiles.active=dev

表示啟用 application-dev.properties 檔案配置, springboot 會載入使用 application.properties 和 application-dev.properties 配置檔案的資訊。

同理,可將 spring.profiles.active 的值修改成 test 或 prod 達到切換環境的目的。

演示圖如下:

image

五、配置日誌

5.1 配置 logback(官方推薦使用)

5.1.1 配置日誌檔案

spring boot 預設會載入 classpath:logback-spring.xml 或者 classpath:logback-spring.groovy。

如需要自定義檔名稱,在 application.properties 中配置 logging.config 選項即可。

在 src/main/resources 下建立 logback-spring.xml 檔案,內容如下:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 檔案輸出格式 -->
    <property name="PATTERN" value="%-12(%d{yyyy-MM-dd HH:mm:ss.SSS}) |-%-5level [%thread] %c [%L] -| %msg%n"/>
    <!-- test檔案路徑 -->
    <property name="TEST_FILE_PATH" value="d:/test.log"/>
    <!-- pro檔案路徑 -->
    <property name="PRO_FILE_PATH" value="/opt/test/log"/>
    
    <!-- 開發環境 -->
    <springProfile name="dev">
        <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
            <encoder>
                <pattern>${PATTERN}</pattern>
            </encoder>
        </appender>
        <logger name="com.light.springboot" level="debug"/>
        <root level="info">
            <appender-ref ref="CONSOLE"/>
        </root>
    </springProfile>
    
    <!-- 測試環境 -->
    <springProfile name="test">
        <!-- 每天產生一個檔案 -->
        <appender name="TEST-FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 檔案路徑 -->
            <file>${TEST_FILE_PATH}</file>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!-- 檔名稱 -->
                <fileNamePattern>${TEST_FILE_PATH}/info.%d{yyyy-MM-dd}.log</fileNamePattern>
                <!-- 檔案最大儲存歷史數量 -->
                <MaxHistory>100</MaxHistory>
            </rollingPolicy>
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>${PATTERN}</pattern>
            </layout>
        </appender>
        <root level="info">
            <appender-ref ref="TEST-FILE"/>
        </root>
    </springProfile>
    
    <!-- 生產環境 -->
    <springProfile name="prod">
        <appender name="PROD_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <file>${PRO_FILE_PATH}</file>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${PRO_FILE_PATH}/warn.%d{yyyy-MM-dd}.log</fileNamePattern>
                <MaxHistory>100</MaxHistory>
            </rollingPolicy>
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>${PATTERN}</pattern>
            </layout>
        </appender>
        <root level="warn">
            <appender-ref ref="PROD_FILE"/>
        </root>
    </springProfile>
</configuration>

其中,springProfile 標籤的 name 屬性對應 application.properties 中的 spring.profiles.active 的配置。

即 spring.profiles.active 的值可以看作是日誌配置檔案中對應的 springProfile 是否生效的開關。

5.2 配置 log4j2

5.2.1 新增依賴

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

5.2.2 配置日誌檔案

spring boot 預設會載入 classpath:log4j2.xml 或者 classpath:log4j2-spring.xml。

如需要自定義檔名稱,在 application.properties 中配置 logging.config 選項即可。

log4j2.xml 檔案內容如下:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <properties>
        <!-- 檔案輸出格式 -->
        
            
           

相關推薦

springboot入門基礎()

一、前言Spring Boot 是由 Pivotal 團隊提供的全新框架,其設計目的是用來簡化新 Spring 應用的初始搭建以及開發過程。該框架使用了特定的方式來進行配置,從而使開發人員不再需要定義樣板化的配置。本系列以快速入門為主,可當作工具小手冊閱讀二、環境搭建建立一個 maven 工程,目錄結構如下圖

Qt入門基礎 ( ) :Qt4及Qt5的下載與安裝

mingw ins 第3版 點擊 調試 但我 關系 構建 eas 轉載請註明出處:CN_Simo. 導語: Qt是一個跨平臺的C++圖形界面應用程序框架。它提供給開發者建立圖形用戶界面所需的功能,廣泛用於開發GUI程序,也可用於開發非GUI程序。Qt很容易擴展,並

Spring Boot 入門基礎

一、前言 Spring Boot 是由 Pivotal 團隊提供的全新框架,其設計目的是用來簡化新 Spring 應用的初始搭建以及開發過程。該框架使用了特定的方式來進行配置,從而使開發人員不再需要定義樣板化的配置。 本系列以快速入門為主,可當作工具小手冊閱讀

Qt入門基礎 ( 二 ) :Qt項目建立、編譯、運行和發布過程解析

qt 5 對話 讓我 進度 qmake ctr deploy 設定 設置 轉載請註明出處:CN_Simo。 題解:   本篇內容主講Qt應用從創建到發布的整個過程,旨在幫助讀者能夠快速走進Qt的世界。   本來計劃是講解Qt源碼靜態編譯,如此的話讀者可能並不能清楚地知

Kears入門基礎

本文轉載自http://www.cnblogs.com/lc1217/p/7132364.html 1.關於Keras         1)簡介               &n

Spark程式設計指南入門Java-基本知識

1. Spark的Java開發包 Spark提供Java的開發包,當前最新版本是2.0.2版本:spark-core_2.11-2.0.2.jar,可以從下面連結下載: http://central.maven.org/maven2/org/apache/spark/spa

MatConvNet使用入門基礎

深度學習在object tracking中的使用也越來越多,從去年的VOT結果來看,很多tracker都應用了convolution feature,整體效果都比之前的方法提高了一大截,所以學習dee

OpenGL ES2.0入門Android()——繪製三角形

OpenGL ES簡介 OpenGL ES是一個為行動式或嵌入式裝置例如:行動電話、監視器等發展的3D繪圖API。 在Android框架中有兩個基礎類用於使用OpenGL ES建立和處理圖形 GLSurfaceView類是OpenGL ES繪製圖形

深度學習:Keras入門()基礎

1.關於Keras         1)簡介                    Keras是由純python編寫的基於theano/tensorflow的深度學習框架。          Keras是一個高層神經網路API,支援快速實驗,能夠把你的idea迅速轉換為

SpringBoot入門Thymeleaf的使用

work pen net 簡單的 xhtml 還需要 pid request 註意 在.net的MVC3 或更高版本等支持 Razor 的框架裏使用cshtml,Razor是一種簡單的編程語法,用於在網頁中嵌入服務器端代碼.在使用springboot開發mvc時也有與.ne

前端開發JavaScript基礎

object 行為 基礎篇 類型轉換 設計 介紹 目的 數據類型轉換 引入 主要內容:   1、JavaScript介紹   2、JavaScript的引入方式   3、javaScript變量和命名規則   4、五種基本數據類型   5、運算符   6、字符串

JAVA常用集合框架用法詳解基礎Colletion介面

首先,在學習集合之前我們能夠使用的可以儲存多個元素的容器就是陣列。 下面舉幾個例子主要是引出集合類的: 1、8,4,5,6,7,55,7,8  像這樣的型別相同的可以使用陣列來儲存,本例可以用int[] arr來儲存。 2、”zhnagsan”,true,68 像這樣的可以使

python+selenium自動測試WebDriver的常用API(基礎

基於python3.6,selenium3.141,詳細資料介紹檢視官方API文件,點選這裡 一、對瀏覽器操作  1 driver = webdriver.Chrome() # 初始化chrome 2 driver1 = webdriver.Firefox() # 初始化Firef

TypeScript基礎入門模組解析()

模組解析 本節假設有關模組的一些基本知識。有關更多資訊,請參閱模組文件。 模組解析是編譯器用來確定匯入所引用內容的過程。 考慮一個匯入語句,如import { a } from "moduleA"; 為了檢查a的任何使用,編譯器需要確切地知道它代表什麼,並且需要檢

Java多執行緒基礎

一、併發和並行 1.1 概念 1.2 比較 1.3 程序和執行緒 二、基礎概念 2.1 執

python3 從基礎入門到高階進階練習題----基礎003

題目:10000以內的一個整數,它加上100和加上268後都是一個完全平方數,請問該數是多少? 程式碼:#!/usr/bin/python3 import math for i in range

學習Qt基礎——從入門開始(1)

Qt 簡介         Qt是一個跨平臺的C++應用程式開發框架,被廣泛用於開發GUI程式。 Qt有豐富的 API且面向物件。Qt是自由且開放原始碼的軟體,在GNU較寬鬆公共許可證條款下發布。支援廣泛的編譯器,包括GCC的C++編譯器和Visual Studio。 Q

SpringBoot入門基礎搭建web應用

引言 之前也沒有深入學習過spring框架,最近SpringBoot流行起來後想補下這方面的知識,於是照著SpringBoot官網上的英文教程開始helloworld入門,踩到幾個小坑,記錄下學習流程。 SpringBoot有哪些優點 SpringBo

Spring Boot 學習基礎

該系列並非完全原創,官方文件、作者Spring Boot 是由 Pivotal 團隊提供的全新框架,其設計目的是用來簡化新 Spring 應用的初始搭建以及開發過程。該框架使用了特定的方式來進行配置,從而使開發人員不再需要定義樣板化的配置。一、環境搭建建立一個Maven專案,

如何天學完python(三)基礎

爬蟲 一個最簡單的爬蟲實現 深複製和淺複製 淺複製就是對引用的拷貝(只拷貝父物件) 深複製就是對對物件的資源的拷貝 兩個標籤指向一個空間,改變任何一個標籤,另一個都會隨之改變 如果不想讓引用之間相互影響 可以使用copy模組 淺拷貝