dubbo通过过滤器filter隐式传参

消费者过滤器,给service层传递用户信息参数

package com.mr.common.filter;


import com.alibaba.fastjson.JSON;
import com.mr.common.constant.Constant;
import com.mr.modules.security.user.UserContext;
import com.mr.modules.security.user.UserDetail;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.apache.dubbo.common.constants.CommonConstants;
import org.apache.dubbo.common.extension.Activate;
import org.apache.dubbo.rpc.*;

/**
 * 登录用户信息消费者过滤器,跨服务传递用户信息参数
 *
 * @author zhuyoulong
 * @date 2023/7/31
 */
@Slf4j
@Activate(group = CommonConstants.CONSUMER)
public class DubboUserInfoConsumerFilter implements Filter {

    @Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
        UserDetail user = UserContext.getUser();
        String userInfo;
        if (user != null) {
            userInfo = JSON.toJSONString(user);
        } else {
            userInfo = RpcContext.getContext().getAttachment(Constant.DUBBO_USER_KEY);
        }
        invocation.getAttachments().put(Constant.DUBBO_USER_KEY, StringUtils.isBlank(userInfo) ? JSON.toJSONString(new UserDetail()) : userInfo);
        return invoker.invoke(invocation);
    }
}

生产者过滤器,接收消费者过滤器传递的用户信息

package com.mr.common.filter;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.TypeReference;
import com.mr.common.constant.Constant;
import com.mr.modules.security.user.UserContext;
import com.mr.modules.security.user.UserDetail;
import lombok.extern.slf4j.Slf4j;
import org.apache.dubbo.common.constants.CommonConstants;
import org.apache.dubbo.common.extension.Activate;
import org.apache.dubbo.rpc.*;

/**
 * dubbo生产者用户过滤器
 *
 * @author zhuyoulong
 * @date 2023/7/31
 */
@Slf4j
@Activate(group = CommonConstants.PROVIDER)
public class DubboUserInfoProviderFilter implements Filter {

    @Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
        String userJson = RpcContext.getContext().getAttachments().get(Constant.DUBBO_USER_KEY);
        if (userJson == null || userJson.contains("{}")) {
            return invoker.invoke(invocation);
        }
        UserDetail userDetail = JSON.parseObject(userJson).toJavaObject(new TypeReference<UserDetail>() {
        });
        UserContext.setUser(userDetail);
        return invoker.invoke(invocation);
    }

}

在生产者项目的resources/META-INF/dubbo/com.alibaba.dubbo.rpc.Filter

dubboUserInfoProviderFilter=com.mr.common.filter.DubboUserInfoProviderFilter

注意这里的Filter第一个字母必须大写,否则在linux环境会提示找不到这个文件,有大小写的问题,如果服务启动出现这个异常No such extension Filter for filter/com.alibaba.dubbo.rpc.Filter,可能Filter的F没大写,我就是写成filter就报这个错误。

生产者application.yml

dubbo:
  provider:
    #去除dubbo默认异常处理过滤器,改用自己的,生产者过滤器
    filter: -exception,dubboUserInfoProviderFilter

在生产者项目的resources/META-INF/dubbo/com.alibaba.dubbo.rpc.Filter

dubboUserInfoConsumerFilter=com.mr.common.filter.DubboUserInfoConsumerFilter

消费者application.yml


dubbo:
  provider:
    #去除dubbo默认异常处理过滤器,改用自己的
    filter: -exception
  consumer:
    filter: dubboUserInfoConsumerFilter

这样就可以了

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值