1.请求先经过SaReactorFilter,进行鉴权
2.实现网关层的GlobalFilter,将loginid 我这里就是username,放入请求头,转发的时候就携带到对应的微服务了
//别忘了将拦截器注册搭配ioc容器中
3.基础服务层使用spring mvc里面的拦截器进行拦截,将loginid加入到threadlocal里面
loginContextHolder就是将loginid放入到threadlocal里面
此时我们就可以使用loginContextholder拿到loginid了
4.常见错误
1.未能读取到有效token 你没有登录,网关全局拦截器执行在SaReactorFilter后面,所以不会执行到获取loginid放入header的带的代码
2.未有有效的上下文,返回错误码为500 请检查muatae.header("loginid",username) username的格式问题,比如含有\r\n字符会导致此错误
在这里因为微服务一直无法获取到上下文,但是我发现username是有值的,所以一直怀疑是网关没有成功转发到对应的微服务耽误了许多时间,实际上是username的格式有问题
如有错误请在评论区指正