栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

dubbo隐式传参,RpcContext,dubbo Session消费端问题

dubbo隐式传参,RpcContext,dubbo Session消费端问题

dubbo 隐式传参+过滤器
  • dubbo,web(消费端)与service(提供端)rpc通信,要传递的实体类必须序列化;有着不同的上下文,web的session,service无法获取。
  • 方案:web获取当前登录人名称,传入RpcContext上下文,隐式传参到service端。通过调用拦截器拦截消费断调用方法,调用前传。
  • 因项目需要,service模块无法获取session,无法获取当前登陆账户。临时采取这种方案,将web端当前登陆用户名传递给RpcContext上下文,供service使用。
  • 先配置调用拦截器,传入用户名到上下文。
//注意版本,2老版本是Constants.CONSUMER,新版本已经弃用,order是为了优先级,越小越优先
@Activate(group={CommonConstants.CONSUMER},order = -10000)
public class RpcContextFilter implements Filter{

	@Override
    public Result invoke(Invoker invoker, Invocation invocation) throws RpcException{
    	if(PrcContext.getContext.isConsumerSide()){
        	String name = LoginUser.getLoginUserName();
            if(null != name){
            	RpcContext.getContext().setAttachment("userName",name);
            }
        
        }
        return invoker.invoke(invocation);
    
    }
}
  • 然后配置文件(spi方式):配置文件meta-INF下创建dubbo文件夹,然后创建纯文件org.apache.dubbo.rpc.Filter。内容xxx = com.xx.x.x.RpcContextFilter,xxx为自定义名称。
dubbo配置文件需要。
# xxx为上面自定义名称
dubbo.consumer.filter = xxx 
  • 注意!2.7阿里捐赠apache后Filter是这个文件名,2.6和之前到可能还是com.alibab.xxx。
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/335773.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号