spring-rpc-case

spring 提供了基本的基于http协议的rpc,同时提供了对rmi 、httpclient3、httpclient4、hession/burlap等相关现有的rpc支持。

rpc :远程方法调用。
效果:在客户端可以通过编程语言调用 服务端的对象。
实现基本思想:在客户端调用方法的时候,把调用的方法名,参数,参数类型通过相关协议传递到服务端,服务端解析到客户端调用的方法、参数等信息,在server端的对象上同样调用此方法,并把调用的结果通过协议返回。
依赖底层技术:java序列化(对象流),http或者tcp 协议。

基于http协议rpc的实现设想:
1、server端启动http协议接口。接受methodname,parameter,parameterTypes
2、clientApp调用远程的方法m1,参数:p1,通过http协议调用接口,传递m1,p1
3、servr端接收到请求,解析到m1,p1,在server端调用m1方法,然后回调客户端的接口,提交server端执行后的数据结果。
4、client收到server端的回调,解析server端执行的结果的数据。(可以同步,也可以异步)

下面是spring rpc 实现的case:

client project
@Controller
@RequestMapping("/login")
public class LoginController {
	private final static Logger logger = LoggerFactory.getLogger(LoginController.class);
	@Autowired
	private ILoginService loginService;
	@RequestMapping("/guest")
	public String login(HttpServletRequest request,HttpServletResponse response){
		logger.info("begin login ");
		User user = loginService.login(request.getParameter("username"), request.getParameter("password"));
		request.setAttribute("username", user.getUsername());
		request.setAttribute("password", user.getPassword());
		logger.info("end login ");
		return "login";
	}
	public ILoginService getLoginService() {
		return loginService;
	}
	public void setLoginService(ILoginService loginService) {
		this.loginService = loginService;
	}
}



applicationContext.xml的配置
<bean name="loginService" class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">
      <property name="serviceUrl" value="http://127.0.0.1:8080/loginServiceInvoker"/>
      <property name="serviceInterface" value="org.job.service.login.ILoginService"/>
   </bean>


servlet-context.xml 的配置
<context:component-scan base-package="org.job.login" >
		<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
		<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
	</context:component-scan>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/"/>
		<property name="suffix" value=".jsp"/>
	</bean>

-------------------------------------------------------------------------------------
server project
servlet-context.xml
<bean name="/loginServiceInvoker" class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">
      <property name="service" ref="loginServiceImpl"/>
      <property name="serviceInterface" value="org.job.service.login.ILoginService"/>
   </bean>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/"/>
		<property name="suffix" value=".jsp"/>
	</bean>

<context:component-scan base-package="org.login.web" >
		<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
		<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
	</context:component-scan>


applicationContext.xml
<bean name="loginServiceImpl" class="org.job.service.login.LoginServiceImpl"/>


你可能感兴趣的:(spring-rpc)