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