Just a little smile ^ ^

yoyo_zeng

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
  112 随笔 :: 3 文章 :: 0 评论 :: 10万 阅读

proxy:将远程方法调用序列化和反序列化

1. 创建 service

2. 创建bean到beanfactory

3. RmiServiceExporter可以将bean export为RMI service,通过把bean包装在设配器中,适配器被绑定在RMI注册表中。

RMI是基于java的,客户端和sever端都需要使用java编写。

public interfaceSpitterService{
List<Spittle>getRecentSpittles(intcount);
void saveSpittle(Spittlespittle);
void saveSpitter(Spitterspitter);
...
}
复制代码
<bean class="org.springframework.remoting.rmi.RmiServiceExporter"
p:service-ref="spitterService"
p:serviceName="SpitterService" //注册的RMI service名称
p:serviceInterface="com.habuma.spitter.service.SpitterService"/>
或者使用
<bean class="org.springframework.remoting.rmi.RmiServiceExporter"
p:service-ref="spitterService"
p:serviceName="SpitterService"
p:serviceInterface="com.habuma.spitter.service.SpitterService"/>
复制代码

 访问service

<bean id="spitterService"
class="org.springframework.remoting.rmi.RmiProxyFactoryBean"
p:serviceUrl="rmi://localhost/SpitterService"
p:serviceInterface="com.habuma.spitter.service.SpitterService"/> //这个服务实现的接口
//Then you can invoke methods on it as if it were a local bean:
public List<Spittle>getSpittles(StringuserName){
    Spitterspitter=spitterService.getSpitter(userName);
    return spitterService.getSpittlesForSpitter(spitter);
}

 

 

使用Hessian and Burlap的远程调用,

二者唯一不同的是Hessian的消息是二进制的,而Burlap是xml的。

和spring类似,HessianServiceExporter 代替RmiServiceExporter,相当于MVC中的controller,不需要注册表

 

复制代码

<bean id="spitterService"
      class="org.springframework.remoting.caucho.BurlapProxyFactoryBean"
      p:serviceUrl="http://localhost:8080/Spitter/spitter.service"
      p:serviceInterface="com.habuma.spitter.service.SpitterService" />
<bean id="hessianSpitterService"
class="org.springframework.remoting.caucho.HessianServiceExporter"
//不需要service-name,因为不需要注册表
p:service-ref="spitterService"
p:serviceInterface="com.habuma.spitter.service.SpitterService"/>
//是controller,需要dispatcherservelet 和 url handler
<servlet-mapping>
<servlet-name>spitter</servlet-name>
<url-pattern>*.service</url-pattern>
</servlet-mapping>

<bean id="urlMapping"class=
"org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<propertyname="mappings">
<value>
/spitter.service=hessianSpitterService
</value>
</property>
</bean>
复制代码

 

 spring 中的 HttpInvoker,用法和以上相同。

 

复制代码
<bean class=
"org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter"
p:service-ref="spitterService"
p:serviceInterface="com.habuma.spitter.service.SpitterService"/>

bean id="spitterService"class=
"org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean"
p:serviceUrl="http://localhost:8080/Spitter/spitter.service"
p:serviceInterface="com.habuma.spitter.service.SpitterService"/>
复制代码

 

参考资料:http://blog.163.com/sejin@126/blog/static/8275045520119894250357/

 

posted on   yoyo_zeng  阅读(357)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
点击右上角即可分享
微信分享提示