1.SpringBoot高級用法
1.1 關于SpringBoot組態檔的說明
1.1.1 properties說明
1.語法: k-v結構 key=value
2.資料型別: 默認是String資料型別 不要添加多余的""號
3.字符資料型別: properties的默認的加載的編碼格式為ISO-8859-1 所以添加中文是需要字符轉意.
4.缺點: 所有的key都必須手動的編輯 沒有辦法復用 所以引入了yml配置
1.1.2 YML 組態檔說明
1.語法 K-V結構 寫法上 key:value 實質上 key=value
key:value中間使用 (:+空格) 分隔
key與key之間有父子級關系的. 所以寫的時候注意縮進項.
YML組態檔默認的格式都是UTF-8編碼 所以可以直接編輯中文
2.例子:
server:
port: 8090
1.2 關于SpringMVC呼叫流程(了解)
1.知識掃盲
1.協議支持 http/https (osi7層網路模型 物數網傳會表應)
2.Java針對于服務器端開發了一種傳輸機制 Servlet機制( TCP-IP協議規范) 用戶使用servlet進行資料的傳輸的速度是較快的.

2.SpringMVC呼叫流程
問題: 用戶發起請求 /addUser 是如何匹配到真實的業務方法的呢???
組件:
1.前端控制器 所有請求的中轉站
2.處理器映射器 將用戶的請求與執行的業務方法進行映射(系結)
3.處理器配接器
4.視圖決議器

1.2 關于組態檔賦值操作
1.2.1 入門案例
package com.jt.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
@RestController //@ResponseBody 將回傳值轉化為json串使用 程式將不會執行視圖決議器 直接回傳
//@Controller //String型別/moduleAndView
public class RedisController {
private String host = "127.0.0.1";
private Integer port = 6379;
//如果使用RestController 回傳值為String型別則回傳字串本身
//如果回傳的是一個物件 則結果必然是該物件的JSON資料.
@RequestMapping("/getMsg")
public String getMsg(){
return host + ":" + port;
}
}
1.2.2 @Value注解屬性賦值
需求: 有時物件中的屬性的值可能會發生變化,如果直接寫死到代碼中可能導致耦合性高. 能否利用組態檔方式動態的為屬性賦值.
package com.jt.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
@RestController //@ResponseBody 將回傳值轉化為json串使用 程式將不會執行視圖決議器 直接回傳
//@Controller //String型別/moduleAndView
public class RedisController {
/**
* 實作思路:
* 如果可以從容器中獲取資料的化,直接賦值給屬性.則可以實作解耦
* 如何實作:
* 注解實作: @Value("${組態檔的key}")
* 運算式: spel 運算式
*/
@Value("${redis.host}")
private String host;
@Value("${redis.port}")
private Integer port;
//如果使用RestController 回傳值為String型別則回傳字串本身
//如果回傳的是一個物件 則結果必然是該物件的JSON資料.
@RequestMapping("/getMsg")
public String getMsg(){
return host + ":" + port;
}
}
1.2.3 利用properties檔案為屬性賦值
說明:由于YML組態檔一般都是配置第三方的整合的資訊,如果將業務的資料添加到YML中則不規范.最好將業務的操作添加到properties檔案中.
添加組態檔:

編輯RedisPro組態檔:
@RestController
//需要通過spring容器加載組態檔,并且以utf-8的格式進行加載
@PropertySource(value="classpath:/properties/redis.properties",encoding = "UTF-8")
public class RedisProController {
@Value("${redis.pro.host}")
private String proHost;
@Value("${redis.pro.port}")
private Integer proPort;
@RequestMapping("/getMsgPro")
public String getMsg2(){
return proHost + ":" + proPort;
}
}
1.3 SpringBoot環境切換問題
1.3.1 業務需求
業務場景:
員工是外包人員,經常性的需要往返公司和甲方,進行代碼除錯時由于位置不同所以服務器IP地址必然不同.如果每次換環境都必須重新編輯IP地址和埠等資料,必定繁瑣能否優化??
1.3.2 業務實作-指定多個環境
注意事項: 無論什么樣的環境,配置的個數都是相同的,只有值不同…
# 該組態檔,當spring容器啟動時加載.
spring:
profiles:
active: prod
---
# 定義開發環境
spring:
profiles: dev
server:
port: 8080
#配置redis節點資訊
redis:
host: 192.168.1.100
port: 6379
# 如果需要多環境配置則需要將YML環境分割
---
spring:
profiles: prod
server:
port: 8090
#配置redis節點資訊
redis:
host: 10.0.0.1
port: 6379
1.4 添加熱部署配置
1.添加jar包檔案
<!--支持熱部署 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
- 配置IDEA工具
組合鍵: ctrl + shift + alt + /

開啟自動編譯即可:

1.5 SpringBoot整合Mybatis
1.5.1 編輯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>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.jt</groupId>
<artifactId>springboot_demo2</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springboot_demo2</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<skipTests>true</skipTests>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.3</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
1.5.2 編輯POJO
package com.jt.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
@Data //動態生成get/set/toString/equals等方法
@Accessors(chain = true) //開啟鏈式加載結構 重構了set方法可以連續.
@NoArgsConstructor //無參構造 必須添加
@AllArgsConstructor //全參構造
public class User {
//物體物件的屬性型別應該都是包裝型別 Integer null
//int=0
private Integer id;
private String name;
private Integer age;
private String sex;
/* 鏈式加載原始碼
public User setId(Integer id){
this.id = id;
return this;
}*/
}
1.5.3 關于LOMBOK面試題
問題: java專案開發完成之后需要在Linux系統中部署專案. 問題:Linux環境中是否需要單獨安裝LomBok插件???
考點: LOMBOK插件作業原理是否清楚…
A: 要 B:不需要
答案:B
決議: LOMBOK插件編譯器有效 xxx.java檔案----編譯-----xxx.class 動態的生成set/get/toString等方法添加到.class檔案中即可. Linux中運行的jar包是.class檔案的集合 已經有了get/set方法.所以不需要引入插件.
1.5.4 關于Sql連接說明
1.serverTimezone=GMT%2B8 %2B 代表 "+"號 表示時區
2.useUnicode=true&characterEncoding=utf8 指定編碼為utf-8
3.autoReconnect=true& 如果程式連接資料庫中途斷掉時是否重連.
4.allowMultiQueries=true 是否允許批量操作
eg: 要求一次入庫3張表資料… 要求用一行sql實作該操作
1.5.5 編輯YML組態檔
server:
port: 8090
servlet:
context-path: /
spring:
datasource:
#驅動版本問題 高版本需要添加cj關鍵字 一般可以省略
#driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/jtdb?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
username: root
password: root
mybatis:
#別名包定義 Mapper的resultType中只需要寫類名 之后自動拼接即可
type-aliases-package: com.jt.pojo
#加載指定的xml映射檔案
mapper-locations: classpath:/mybatis/mappers/*.xml
#開啟駝峰映射
configuration:
map-underscore-to-camel-case: true
1.5.6 關于知識點講解-mapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--namespace:一般與介面的路徑一致-->
<mapper namespace="com.jt.mapper.UserMapper">
<!--<select id="findAll" resultType="User">
select * from user
</select>-->
<!--
業務需求:
要求實作資料庫的查詢,但是資料庫表欄位與物件的屬性不一致.
eg:
user表(欄位 user_id,user_name,user_age......)
User物件(屬性 userId,userName,userAge)
說明: 引入駝峰映射規則.
執行順序: 1獲取user_id~~~~去掉多余的"_"字母大寫 ~~~~userId
實作資料的映射.
注意事項: 如果使用駝峰規則映射則必須滿足規范..
-->
<!--<select id="find" resultType="" resultMap="手動封裝"></select>-->
</mapper>
1.5.7 代碼結構

1.5.8 關于AutoWired 報錯問題

作業
1. ORM思想
2. 提前預習MybatisPlus https://baomidou.com/ 面向物件的方式操作資料庫 以后單表操作幾乎不寫sql
3. 常用ajax用法 jquery $.get() $.post() $.getJSON() $.ajax()
明確概念: 回呼函式!!!!!
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/196792.html
標籤:其他
