詳解SpringBoot通用配置文件(不定時更新)
以下是SpringBoot項目中的常用配置類、jar包坐標(biāo)等通用配置
pom文件
<!-- --> <!-- 自定義配置文件提示 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> <!-- Redis啟動器 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <!-- SpringSession解決session共享問題--> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency> <!-- RabbitMQ啟動器 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> <!-- 熱部署啟動器 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> </dependency> <!-- thymeleaf模板引擎 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <!-- hutool工具包 --> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.5.9</version> </dependency> <!-- 阿里巴巴Fastjson工具包 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.75</version> </dependency> <!-- 注解校驗啟動器 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency> <!-- mybatis啟動器 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.4</version> </dependency> <!-- mybatis-plus啟動器 --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.2</version> </dependency> <!-- MySQL驅(qū)動包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.23</version> </dependency> <!-- Nacos 服務(wù)注冊發(fā)現(xiàn) --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!-- nacos 配置中心 --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency>
常用配置類
Feign遠(yuǎn)程調(diào)用攔截器配置
@Configuration
public class FeignConfig {
@Bean
public RequestInterceptor requestInterceptor() {
return new RequestInterceptor() {
/**
* 調(diào)用遠(yuǎn)程方法之前先調(diào)用此方法
*/
@Override
public void apply(RequestTemplate requestTemplate) {
//Spring提供的工具,獲取當(dāng)前請求的屬性,
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
//獲取當(dāng)前請求對象
HttpServletRequest request = requestAttributes.getRequest();
//同步請求頭信息
requestTemplate.header("Cookie", request.getHeader("Cookie"));
}
};
}
}
常用方法
分布式中進行線程數(shù)據(jù)共享-----ThreadLocal
例如:在分布式服務(wù)中,進行登錄后怎樣將當(dāng)前登錄的用戶在當(dāng)前微服務(wù)中,可以通過ThreadLocal類型進行共享
// 示例,前后端分離環(huán)境
/**
* 在連接器中進行攔截驗證
*/
public class MyInterceptor implements HandlerInterceptor{
public static ThreadLocal<User> loginUser = new ThreadLocal<>();
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 獲取系統(tǒng)頒發(fā)的token
String token = request.getHeader("token");
// TODO 在認(rèn)證服務(wù)中心通過token去認(rèn)證當(dāng)前是否有賬戶登錄及其登錄的狀態(tài)
User user = feign.validUser(token);
//將用戶信息保存到本地線程中
loginUser.set(user);
}
}
/**
* 測試demo
*/
public class TestDemo{
public void test(){
// 從本地線程中獲取保存的變量
User user = MyInterceptor.loginUser.get();
// TODO 使用user進行業(yè)務(wù)
}
}
Feign同步調(diào)用時丟失請求頭信息—添加攔截器
@Configuration
public class FeignConfig {
@Bean
public RequestInterceptor requestInterceptor() {
return new RequestInterceptor() {
/**
* 調(diào)用遠(yuǎn)程方法之前先調(diào)用此方法
*/
@Override
public void apply(RequestTemplate requestTemplate) {
//Spring提供的工具,獲取當(dāng)前請求的屬性,
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
//獲取當(dāng)前請求對象
HttpServletRequest request = requestAttributes.getRequest();
//同步請求頭信息
requestTemplate.header("Cookie", request.getHeader("Cookie"));
}
};
}
}
Feign異步調(diào)用時丟失上下文
public void testDemo() throws ExecutionException, InterruptedException {
// 主線程請求的上下文信息
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
CompletableFuture<Void> task1 = CompletableFuture.runAsync(() -> {
//設(shè)置上下文信息
RequestContextHolder.setRequestAttributes(requestAttributes);
//TODO 執(zhí)行遠(yuǎn)程調(diào)用
}, executor);
CompletableFuture<Void> task2 = CompletableFuture.runAsync(() -> {
//設(shè)置上下文信息
RequestContextHolder.setRequestAttributes(requestAttributes);
//TODO 執(zhí)行遠(yuǎn)程調(diào)用
}, executor);
CompletableFuture.allOf(task1, task2).get();
}
// TODO feign的攔截器代碼不用改
到此這篇關(guān)于詳解SpringBoot通用配置文件(不定時更新)的文章就介紹到這了,更多相關(guān)SpringBoot配置文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Scala數(shù)據(jù)庫連接池的簡單實現(xiàn)
本文主要介紹了Scala數(shù)據(jù)庫連接池的簡單實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
idea使用war以及war exploded的區(qū)別說明
本文詳細(xì)解析了war與warexploded兩種部署方式的差異及步驟,war方式是先打包成war包,再部署到服務(wù)器上;warexploded方式是直接把文件夾、class文件等移到Tomcat上部署,支持熱部署,開發(fā)時常用,文章分別列出了warexploded模式和war包形式的具體操作步驟2024-10-10
使用Java進行Json數(shù)據(jù)的解析(對象數(shù)組的相互嵌套)
下面小編就為大家?guī)硪黄褂肑ava進行Json數(shù)據(jù)的解析(對象數(shù)組的相互嵌套)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
解決SpringCloud?Feign異步調(diào)用傳參問題
這篇文章主要介紹了SpringCloud?Feign異步調(diào)用傳參問題,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
Java工程使用ffmpeg進行音視頻格式轉(zhuǎn)換的實現(xiàn)
FFmpeg是一套可以用來記錄、轉(zhuǎn)換數(shù)字音頻、視頻,并能將其轉(zhuǎn)化為流的開源計算機程序,本文主要介紹了Java工程使用ffmpeg進行音視頻格式轉(zhuǎn)換的實現(xiàn)2024-02-02

