spring-rpc-case

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

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

[b]基于http协议rpc的实现设想:[/b]
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:

[b]client project[/b]

@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>

-------------------------------------------------------------------------------------
[b]server project[/b]
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"/>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值