dubbo隱式傳值實例


1.一般登錄的時候可能要保存的值,用ThreadLocal保存

package com.banksteel.openerp.commons.filter;

public class SaasParameter {

	// 創建線程局部變量,並初始化值
	private static ThreadLocal<String> memberIdThreadLocal = new ThreadLocal<String>() {
		protected String initialValue() {
			return "";
		};
	};

	// 提供線程局部變量set方法
	public static void setMemberId(String memberId) {
		memberIdThreadLocal.set(memberId);
	}

	// 提供線程局部變量get方法
	public static String getMemberId() {
		return memberIdThreadLocal.get();
	}
}

2,要保存的值

SaasParameter.setMemberId(“xxxx”);

 

3.web層的comsumer

dubbo-comsumer.xml 配置監聽

<dubbo:consumer filter="${dubbo.consumer.filter}" timeout="${dubbo.consumer.timeout}" check="false" />

4.監聽的java類。把SaasParameter里面的值給dubbo

package com.banksteel.openerp.commons.filter;

import com.alibaba.dubbo.rpc.Filter;
import com.alibaba.dubbo.rpc.Invocation;
import com.alibaba.dubbo.rpc.Invoker;
import com.alibaba.dubbo.rpc.Result;
import com.alibaba.dubbo.rpc.RpcException;

public class SaasConsumerFilter implements Filter {

	@Override
	public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
          //把SassParameter里面的值放到dubbo監聽的invoke里面 invocation.getAttachments().put("memberId", SaasParameter.getMemberId()); Result result = invoker.invoke(invocation); return result; } }

5.service的provider提供方

dubbo-provider.xml 配置監聽

<dubbo:provider filter="${dubbo.provider.filter}"
		timeout="${dubbo.provider.timeout}" />

6.監聽的java類,把dubbo里面的值再給SaasParameter

package com.banksteel.openerp.commons.filter;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.alibaba.dubbo.rpc.Filter;
import com.alibaba.dubbo.rpc.Invocation;
import com.alibaba.dubbo.rpc.Invoker;
import com.alibaba.dubbo.rpc.Result;
import com.alibaba.dubbo.rpc.RpcException;
import com.alibaba.dubbo.rpc.RpcResult;

import cn.mysteel.util.StringUtils;

public class SaasProviderFilter implements Filter {

	private Logger logger = LoggerFactory.getLogger(SaasProviderFilter.class);

	@Override
	public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
		String memberId = invocation.getAttachments().get("memberId");
		SaasParameter.setMemberId(memberId);

		return invoker.invoke(invocation);
	}
}

7,service層調用SaasParameter的值

SaasParameter.getMemberId()

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM