詳解SpringBoot通用配置文件(不定時更新)
以下是SpringBoot項目中的常用配置類、jar包坐標等通用配置
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 服務注冊發(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遠程調(diào)用攔截器配置
@Configuration
public class FeignConfig {
@Bean
public RequestInterceptor requestInterceptor() {
return new RequestInterceptor() {
/**
* 調(diào)用遠程方法之前先調(diào)用此方法
*/
@Override
public void apply(RequestTemplate requestTemplate) {
//Spring提供的工具,獲取當前請求的屬性,
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
//獲取當前請求對象
HttpServletRequest request = requestAttributes.getRequest();
//同步請求頭信息
requestTemplate.header("Cookie", request.getHeader("Cookie"));
}
};
}
}
常用方法
分布式中進行線程數(shù)據(jù)共享-----ThreadLocal
例如:在分布式服務中,進行登錄后怎樣將當前登錄的用戶在當前微服務中,可以通過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 在認證服務中心通過token去認證當前是否有賬戶登錄及其登錄的狀態(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è)務
}
}
Feign同步調(diào)用時丟失請求頭信息—添加攔截器
@Configuration
public class FeignConfig {
@Bean
public RequestInterceptor requestInterceptor() {
return new RequestInterceptor() {
/**
* 調(diào)用遠程方法之前先調(diào)用此方法
*/
@Override
public void apply(RequestTemplate requestTemplate) {
//Spring提供的工具,獲取當前請求的屬性,
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
//獲取當前請求對象
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(() -> {
//設置上下文信息
RequestContextHolder.setRequestAttributes(requestAttributes);
//TODO 執(zhí)行遠程調(diào)用
}, executor);
CompletableFuture<Void> task2 = CompletableFuture.runAsync(() -> {
//設置上下文信息
RequestContextHolder.setRequestAttributes(requestAttributes);
//TODO 執(zhí)行遠程調(diào)用
}, executor);
CompletableFuture.allOf(task1, task2).get();
}
// TODO feign的攔截器代碼不用改
到此這篇關于詳解SpringBoot通用配置文件(不定時更新)的文章就介紹到這了,更多相關SpringBoot配置文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
如何自定義hibernate validation注解示例代碼
Hibernate Validator 是 Bean Validation 的參考實現(xiàn) . Hibernate Validator 提供了 JSR 303 規(guī)范中所有內(nèi)置 constraint 的實現(xiàn),下面這篇文章主要給大家介紹了關于如何自定義hibernate validation注解的相關資料,需要的朋友可以參考下2018-04-04
SpringBoot整合Mybatis自定義攔截器不起作用的處理方案
這篇文章主要介紹了SpringBoot整合Mybatis自定義攔截器不起作用的處理方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
IDEA創(chuàng)建Java項目保姆級教程(超詳細!)
這篇文章主要給大家介紹了關于IDEA創(chuàng)建Java項目保姆級教程的相關資料,Java是一種廣泛使用的編程語言,廣泛用于Web應用程序和客戶端應用程序的開發(fā),文中通過圖文介紹的非常詳細,需要的朋友可以參考下2023-09-09
Spring中@Configuration和@Component注解的區(qū)別及原理
這篇文章主要介紹了Spring中@Configuration和@Component注解的區(qū)別及原理,從功能上來講,這些注解所負責的功能的確不相同,但是從本質(zhì)上來講,Spring內(nèi)部都將其作為配置注解進行處理,需要的朋友可以參考下2023-11-11
Sping?Security前后端分離兩種實戰(zhàn)方案
這篇文章主要介紹了Sping?Security前后端分離兩種方案,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03

