Java SpringBoot高級用法詳解

1,IDEA中Lombok作用

數據庫: 庫 表 字段 對應的值 user表(id,name,age)

實體對象pojo: 用來封裝數據庫中的數據 User類(id,name,age)

實體對象方法: Get/Set/toString/無參構造/有參構造/equals/hashcode

lombok作用: 自動生成上述的方法.

創建項目

依賴的版本 2.4.1、

2.pom.xml說明

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
<!--  該配置表示Maven坐標  -->
<!--  項目的組id  -->
    <groupId>com.jt</groupId>
<!--  項目名稱  -->
    <artifactId>springboot_demo1</artifactId>
<!--  項目版本號 -->
    <version>0.0.1-SNAPSHOT</version>
    <name>springboot_demo1</name>
    <description>Demo project for Spring Boot</description>
 
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <spring-boot.version>2.4.1</spring-boot.version>
    </properties>
 
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <!--  SpringBoot的啟動項   wep  相當於引入MVC框架
                    思想:"開箱即用"!!!
                    說明: 隻需要引入jar包,簡單的配置即可以使用該功能
                 -->
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
 
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
 
    <dependencyManagement>
        <dependencies>
            <!--相當於繼承瞭一個父級-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <!--通過pom標識 是一個父級 -->
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
 
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.4.1</version>
                <configuration>
                    <mainClass>com.jt.SpringbootDemo1Application</mainClass>
                </configuration>
                <executions>
                    <execution>
                        <id>repackage</id>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
 
</project>

2.1 pom.xml標簽說明

說明: 該坐標在本地倉庫中是唯一標識符.是當前項目打包/被依賴的唯一 路徑.

根據坐標查找jar包

擴展: 如果項目中依賴第三方jar包文件報錯! 如何處理?

問題說明: 有時根據坐標下載jar包文件時,可能由於網絡問題,導致jar包下載不完整.

解決方案: 根據第三方的坐標,查找到本地倉庫的位置,之後刪除 重新下載.

  • 默認條件下 jar包
  • web項目可以打成 war包
  • 如果該項目是父級項目 則寫 pom

通過dependencyManagement標簽統一定義父級工程,在其中定義瞭 springBoot項目所有兼容的版本信息.

所以依賴項中不需要添加版本號,也可以正常依賴jar包文件

2.2 依賴的相關說明

思想: “開箱即用” 是springBoot設計的核心 越來越簡單!!!

什麼是啟動項: SpringBoot為整合第三方框架,寫瞭啟動項的jar包文件, 其中官方已經將所有的配置信息/需要依賴的jar包文件提前測試並且定義.

說明: maven中的jar包是有依賴的傳遞性

例如: A項目依賴B.jar包, B.jar依賴C.jar. 在項目中,隻需要添加B.jar. 則B/C.jar都會自動添加.

實際應用: 如圖web.jar包中依賴瞭很多其它的第三方jar包文件.

mavenjar包查詢網址: https://mvnrepository.com/

本地倉庫文件說明:

1. 當maven開始解析項目的POM.xml文件時,根據依賴的坐標,找到指定的 jar包文件.之後添加該依賴.

2. 之後掃描當前文件中的 xxx.pom文件.

3. 掃描pom.xml文件中的依賴信息dependency

4. 根據dependency的坐標 重復執行上述的操作.直到所有的依賴都添加完 成.

需求: 網絡數據傳輸,一般都需要進行加密處理.maven中采用SHA1數字簽 名的加密算法,保證數據傳遞的有效性!!!

說明: maven數據傳遞有效性原理圖.

2.3 SHA1介紹

SHA-1(英語:Secure Hash Algorithm 1,中文名:安全散列算法1)是一種密碼散列函 數,美國國傢安全局設計,並由美國國傢標準技術研究所(NIST)發佈為聯邦數據處理 標準(FIPS)。SHA-1可以生成一個被稱為消息摘要的160位(20字節)散列值,散列 值通常的呈現形式為**40個十六進制數**。

關鍵字: 數字證書.

問題1: 常見hashcode值 有多少位16進制數組成??? 8位

問題2: 8位16進制數,有多少種排列組合? 2^32種

00000000-FFFFFFFF

問題3: 相同數據進行hash(算法相同),問題: 值是否相同? 必定相同

問題4: 不同數據進行hash(算法相同),問題: 值是否相同? 可能相同 hash碰撞

問題5: 一個數據1kb, 一個數據ITB 問: hash計算的速度誰快? “一樣快” hash本質

SpringBoot高級用法

Pro文件說明

  • pro文件語法
  • 數據結構類型:   key=value  特別註意不要有空格.
  • 字符集編碼:    程序讀取文件時,默認采用ISO-8859-1編碼
  • 弊端: 所有的key都必須寫完整,不能縮進

YML文件說明

YML文件的語法

  • 數據結構   key-value結構
  • 寫法:     key:(空格)value
  • 層級代碼結構,註意縮進
  • 字符集  文件讀取時,默認采用UTF-8編碼 可以寫中文

server:

  port: 8080

3.需求說明

說明: 有時將數據寫死,不方便後續擴展,需要為屬性動態賦值.
解決方案: 有些數據是後臺特有的.一般可以將數據寫到配置文件中,之後 為屬性動態賦值

編輯YML

#YML文件的語法
#1,數據結構  key-value結構
#2,寫法:    key:(空格)value
#3,層及代碼結構,註意縮進
#4,字符集 文件讀取時,默認采取UTF-8編碼 可以寫中文
# 規則: 命名時最好指定前綴.
server:
  port: 8080
  # 指定業務的key
mysql:
  Username: root|
  Password: root||

 啟動類

package com.jt;
 
//import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//import org.springframework.web.bind.annotation.RequestMapping;
 
@SpringBootApplication
public class SpringbootDemo1Application {
 
    public static void main(String[] args) {
        SpringApplication.run(SpringbootDemo1Application.class, args);
    }
 
    }

 動態為屬性賦值

package com.jt.contraller;
 
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
/**
 * 說明:
 *  1.將該類交給Spring容器管理
 *  2.SpringMVC負責調用該對象接收用戶的請求.
 *  3.將業務處理之後的結果,為頁面返回JSON數據.
 *  @ResponseBody作用: 將數據轉化為JSON串
 */
@RestController
public class JDBCController {
    //${key} Spring提供的springel表達式 簡稱為:spel表達式
    //語法: 從spring容器內部獲取key,動態為屬性賦值.
    @Value("${mysql.username}")
    String username;    // = "root|";
    @Value("${mysql.password}")
    String password;    // = "root";
 
    @RequestMapping("/getMsg")
    public String getMsg() {
        return "你好數據庫:" + username + password;
    }
}

3.2利用properties文件為屬性賦值

YML文件是SpringBoot的核心配置文件,一般主要用來整合其它第三方框架.屬於系統配置文件.如果將大量的業務數據寫到系統配置文件中. 耦合性高. 所以將業務數據最好放到pro文件中.

配置 pro 文件

#默認ISO-8859-1 中文必定亂碼
mysql.username2=mysql數據庫
mysql.password2=你猜猜

為屬性賦值

package com.jt.contraller;
 
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
 * 說明:
 *  1.將該類交給Spring容器管理
 *  2.SpringMVC負責調用該對象接收用戶的請求.
 *  3.將業務處理之後的結果,為頁面返回JSON數據.
 *  @ResponseBody作用: 將數據轉化為JSON串
 *
 *  propertySource:  value屬性指定路徑
 *                   encoding屬性指定配置文件編碼格式
 */
@RestController
@PropertySource(value="classpath:/mysql.properties",encoding = "UTF-8")
public class JDBCContraller {
    /**
     * 難點: 如何將pro文件交給Spring容器管理????
     * 解決方案: @PropertySource("xxxxxx/xxx.properties") 指定配置文件交給Spring
     *          容器管理
     */
    @Value("${mysql.username2}")
    private String username2;
    @Value("${mysql.password2")
    private String password2;
 
    @RequestMapping("/getMsg2")
    public String getMsg2(){
 
        return "你好數據庫:"+ username2 +password2;
    }
}

結構

總結

本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!

推薦閱讀: