springcloud微服务之间无需传递request参数传递cookie信息的一种方法

springcloud微服务之间无需传递request参数传递cookie信息的一种方法

  • 先说明一下

本例中MemberServiceImpl(代码见后边)中拿到的cookie值实际上是通过在header添加自定义字段来传递,在MemberServiceImpl中用getHeader来获取的,因为用fegin进行远程调用的request并不是第三方请求中的request,而在用拦截器对fegin请求进行拦截时拦截的是fegin进行远程调用的request里面不含第三方请求cookie,java中request对象无法设置cookie,所以采用消息头来传递cookie信息。

  • 测试结果贴出来:

开始时cookie为空,本例以重定向方式测试,因为转发的话直接请求方法的request和转发到的方法的request相当于是同一个,而重定向是请求方法的request和重定向到的方法request是不同的,要是设置cookie的话,重定向到的方法也会拿到在直接请求的方法中设置的cookie值。

请求两次:
第一次请求,请求forward方法时cookie前值为null,重定向到testRequestCookie方法后的值为test_cookie999
在这里插入图片描述
MemberServiceImpl中可以获取到传递的cookie值,为test_cookie999,因为传送的值是在重定向到testRequestCookie方法中后发送的,此时的request中已经携带了消息头
在这里插入图片描述

第二次请求,仍然以重定向方式测试,请求forward方法的值和重定向到testRequestCookie方法后的值一样,都为test_cookie999,因为第一次请求已经设置了cookie,而第二次设置的cookie值和第一次一样,故而值一样
在这里插入图片描述
第二次请求MemberServiceImpl中cookie值仍然为test_cookie999
在这里插入图片描述

  • happy-paying-web-pc工程(前端web微服务)下MemberServiceFegin远程调用会员微服务,以下是部分代码:
@Component
//value=fegin服务名,configuration=Request拦截器.class
@FeignClient(value="member",configuration=HeaderInterceptor.class)
public interface MemberServiceFegin extends MemberService {

}
  • happy-paying-web-pc工程下Request拦截器,拦截fegin远程调用请求,添加消息头
import javax.servlet.http.HttpServletRequest;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import com.vttsor.utils.CookieUtil;

import feign.RequestInterceptor;
import feign.RequestTemplate;
import lombok.extern.slf4j.Slf4j;

@Slf4j
@Configuration
public class HeaderInterceptor  implements RequestInterceptor{

	@Override
	public void apply(RequestTemplate template) {
		HttpServletRequest request = ((ServletRequestAttributes) (RequestContextHolder.currentRequestAttributes())).getRequest();
		//CookieUtil为自定义操作Cookie的工具
		String testCookie = CookieUtil.getCookie(request, "test_cookie_key");
		log.info("testCookie is {}",testCookie);
		template.header("test_cookie_key", testCookie);
	}

}
  • happy-paying-web-pc工程下MemberController,用于接收第三方请求,以下是部分代码:
@Autowired
    private MemberServiceFegin memberServiceFegin;

    @ResponseBody
    @RequestMapping(value="/testRequest",method = RequestMethod.GET)
    public String testRequestCookie(HttpServletResponse response){
    	//testRequest方法的参数未用到
    	memberServiceFegin.testRequest("testRequest");
    	return "testRequest";
    }
    
    @RequestMapping(value="/testForward",method = RequestMethod.GET)
    public String forward(HttpServletRequest request,HttpServletResponse response){
    	log.info("forwardRequestCookie is {}",CookieUtil.getCookie(request, "test_cookie_key"));
    	CookieUtil.addCookie(response,"test_cookie_key","test_cookie999",Constants.TOKEN_MEMBER_TIME);
    	
    	//转发
    	//return "forward:testRequest";
    	//重定向
		return "redirect:testRequest";
    }
  • happy-paying-member工程(会员微服务)下MemberServiceImpl部分代码,MemberServiceImpl实现了happy-paying-api工程下的happy-paying-member-api工程的MemberService接口。ResponseBase 封装了返回结果,代码略,别纠结。
//远程调用时,第二种获取request的方式,简洁,但是成员变量
@Autowired
private HttpServletRequest req;

	@Override
	//testRequest方法的参数未用到
	public ResponseBase testRequest(String testParam) {
		//远程调用时,第一种获取request的方式,繁琐,但是可以是局部变量
    	HttpServletRequest request = ((ServletRequestAttributes) (RequestContextHolder.currentRequestAttributes())).getRequest();
    	if(null != request){
    		log.info("\nrequest is  {}" ,request);
    		log.info("\nthe test_cookie_key"+" is  {}" ,request.getHeader("test_cookie_key"));
    	}else{
    		log.info("\nrequest is  {}" ,"null");
    	}
    	
    	if(null != req){
    		log.info("\nreq is  {}" ,req);
    		log.info("\nthe test_cookie"+" is  {}" ,request.getHeader("test_cookie_key"));
    	}else{
    		log.info("\nreq is  {}" ,"null");
    	}
		return setSusResult();
	}
  • happy-paying-api工程(接口工程,提供给其他微服务)下happy-paying-member-api子工程的MemberService接口
	// request测试,testRequest方法的参数未用到
    @RequestMapping(value="/testRequest",method = RequestMethod.GET)
    ResponseBase testRequest(@RequestParam("testParam") String testParam);
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值