java配置文件强制更新,详解SpringBoot通用配置文件(不定时更新)

以下是SpringBoot项目中的常用配置类、jar包坐标等通用配置

pom文件

org.springframework.boot

spring-boot-configuration-processor

true

org.springframework.boot

spring-boot-starter-data-redis

org.springframework.session

spring-session-data-redis

org.springframework.boot

spring-boot-starter-amqp

org.springframework.boot

spring-boot-devtools

true

org.springframework.boot

spring-boot-starter-thymeleaf

cn.hutool

hutool-all

5.5.9

com.alibaba

fastjson

1.2.75

org.springframework.boot

spring-boot-starter-validation

org.mybatis.spring.boot

mybatis-spring-boot-starter

2.1.4

com.baomidou

mybatis-plus-boot-starter

3.4.2

mysql

mysql-connector-java

8.0.23

com.alibaba.cloud

spring-cloud-starter-alibaba-nacos-discovery

com.alibaba.cloud

spring-cloud-starter-alibaba-nacos-config

常用配置类

Feign远程调用拦截器配置

@Configuration

public class FeignConfig {

@Bean

public RequestInterceptor requestInterceptor() {

return new RequestInterceptor() {

/**

* 调用远程方法之前先调用此方法

*/

@Override

public void apply(RequestTemplate requestTemplate) {

//Spring提供的工具,获取当前请求的属性,

ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();

//获取当前请求对象

HttpServletRequest request = requestAttributes.getRequest();

//同步请求头信息

requestTemplate.header("Cookie", request.getHeader("Cookie"));

}

};

}

}

常用方法

分布式中进行线程数据共享-----ThreadLocal

例如:在分布式服务中,进行登录后怎样将当前登录的用户在当前微服务中,可以通过ThreadLocal类型进行共享

// 示例,前后端分离环境

/**

* 在连接器中进行拦截验证

*/

public class MyInterceptor implements HandlerInterceptor{

public static ThreadLocal loginUser = new ThreadLocal<>();

@Override

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

// 获取系统颁发的token

String token = request.getHeader("token");

// TODO 在认证服务中心通过token去认证当前是否有账户登录及其登录的状态

User user = feign.validUser(token);

//将用户信息保存到本地线程中

loginUser.set(user);

}

}

/**

* 测试demo

*/

public class TestDemo{

public void test(){

// 从本地线程中获取保存的变量

User user = MyInterceptor.loginUser.get();

// TODO 使用user进行业务

}

}

Feign同步调用时丢失请求头信息—添加拦截器

@Configuration

public class FeignConfig {

@Bean

public RequestInterceptor requestInterceptor() {

return new RequestInterceptor() {

/**

* 调用远程方法之前先调用此方法

*/

@Override

public void apply(RequestTemplate requestTemplate) {

//Spring提供的工具,获取当前请求的属性,

ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();

//获取当前请求对象

HttpServletRequest request = requestAttributes.getRequest();

//同步请求头信息

requestTemplate.header("Cookie", request.getHeader("Cookie"));

}

};

}

}

Feign异步调用时丢失上下文

public void testDemo() throws ExecutionException, InterruptedException {

// 主线程请求的上下文信息

RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();

CompletableFuture task1 = CompletableFuture.runAsync(() -> {

//设置上下文信息

RequestContextHolder.setRequestAttributes(requestAttributes);

//TODO 执行远程调用

}, executor);

CompletableFuture task2 = CompletableFuture.runAsync(() -> {

//设置上下文信息

RequestContextHolder.setRequestAttributes(requestAttributes);

//TODO 执行远程调用

}, executor);

CompletableFuture.allOf(task1, task2).get();

}

// TODO feign的拦截器代码不用改

到此这篇关于详解SpringBoot通用配置文件(不定时更新)的文章就介绍到这了,更多相关SpringBoot配置文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值