响应的服务端骨架类:
package com.caucho.burlap.server;
import com.caucho.burlap.io.BurlapInput;
import com.caucho.burlap.io.BurlapOutput;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.HashMap;
public class BurlapSkeleton
{
public BurlapSkeleton(Object service)
{
_methodMap = new HashMap();
_service = service;
Method methodList[] = service.getClass().getMethods();
for(int i = 0; i < methodList.length; i++)
{
Method method = methodList[i];
if(_methodMap.get(method.getName()) == null)
_methodMap.put(method.getName(), methodList[i]);
Class param[] = method.getParameterTypes();
String mangledName = method.getName() + "__" + param.length;
_methodMap.put(mangledName, methodList[i]);
_methodMap.put(mangleName(method, false), methodList[i]);
}
}
protected String mangleName(Method method, boolean isFull)
{
StringBuffer sb = new StringBuffer();
sb.append(method.getName());
Class params[] = method.getParameterTypes();
for(int i = 0; i < params.length; i++)
{
sb.append('_');
mangleClass(sb, params[i], isFull);
}
return sb.toString();
}
private void mangleClass(StringBuffer sb, Class cl, boolean isFull)
{
String name = cl.getName();
if(name.equals("boolean") || name.equals("java.lang.Boolean"))
sb.append("boolean");
else
if(name.equals("int") || name.equals("java.lang.Integer") || name.equals("short") || name.equals("java.lang.Short") || name.equals("byte") || name.equals("java.lang.Byte"))
sb.append("int");
else
if(name.equals("long") || name.equals("java.lang.Long"))
sb.append("long");
else
if(name.equals("float") || name.equals("java.lang.Float") || name.equals("double") || name.equals("java.lang.Double"))
sb.append("double");
else
if(name.equals("java.lang.String") || name.equals("com.caucho.util.CharBuffer") || name.equals("char") || name.equals("java.lang.Character") || name.equals("java.io.Reader"))
sb.append("string");
else
if(name.equals("java.util.Date") || name.equals("com.caucho.util.QDate"))
sb.append("date");
else
if((java.io.InputStream.class).isAssignableFrom(cl) || name.equals("[B"))
sb.append("binary");
else
if(cl.isArray())
{
sb.append("[");
mangleClass(sb, cl.getComponentType(), isFull);
} else
if(name.equals("org.w3c.dom.Node") || name.equals("org.w3c.dom.Element") || name.equals("org.w3c.dom.Document"))
sb.append("xml");
else
if(isFull)
{
sb.append(name);
} else
{
int p = name.lastIndexOf('.');
if(p > 0)
sb.append(name.substring(p + 1));
else
sb.append(name);
}
}
public void invoke(BurlapInput in, BurlapOutput out)
throws Throwable
{
in.startCall();
String methodName = in.getMethod();
Method method = (Method)_methodMap.get(methodName);
if(method == null)
if(methodName.equals("_burlap_getAttribute"))
{
getBurlapAttribute(in, out);
return;
} else
{
throw new IOException("No server method matching:" + in.getMethod());
}
Class args[] = method.getParameterTypes();
Object values[] = new Object[args.length];
for(int i = 0; i < args.length; i++)
values[i] = in.readObject(args[i]);
in.completeCall();
Object result = null;
try
{
result = method.invoke(_service, values);
}
catch(Throwable e)
{
if(e instanceof InvocationTargetException)
e = ((InvocationTargetException)e).getTargetException();
out.startReply();
out.writeFault("ServiceException", e.getMessage(), e);
out.completeReply();
return;
}
out.startReply();
out.writeObject(result);
out.completeReply();
}
public void getBurlapAttribute(BurlapInput in, BurlapOutput out)
throws IOException
{
String name = in.readString();
in.completeCall();
out.startReply();
if(name.equals("home-class") || name.equals("remote-class"))
{
Class cl = _service.getClass();
Class interfaces[] = cl.getInterfaces();
String homeClass = null;
for(int i = 0; i < interfaces.length; i++)
if((java.rmi.Remote.class).isAssignableFrom(interfaces[i]) && (java.rmi.Remote.class) != interfaces[i])
homeClass = interfaces[i].getName();
if(homeClass == null)
homeClass = cl.getName();
out.writeString(homeClass);
} else
{
out.writeObject(null);
}
out.completeReply();
}
private HashMap _methodMap;
private Object _service;
}
相关推荐
Burlap是一个轻量级的XML RPC协议 这使得他可以移植到任何可以解析XML的语言中 比起Hessian 它的可读性更强 和其他基于Xml的远程技术(如SOAP和XML RPC)不同 它的消息结构尽可能简单 不需要额外的外部定义语言 如...
使用eclipse maven工程搭建hessian远程服务demo 分服务端的整合和客户端 建议阅读相关博客http://blog.csdn.net/heisemuyangquan/article/details/79460528
然后,他可能会讲述如何在Java环境中设置Hessian服务,包括添加依赖库、创建服务接口和服务实现、配置服务器和客户端。此外,还可能涉及到如何使用Hessian的Binder来暴露和调用服务。 对于Burlap,作者可能会对比...
至于"List"和"Map",它们在Hessian中也有特别的处理方式。Hessian可以序列化和反序列化List和Map类型的集合,无论是基本类型还是自定义对象的集合。在Java端,`List`和`Map`会被转换成Hessian的特定格式,而在C#端,...
Hessian和Burlap是两种高效且简洁的网络通信协议,尤其适用于需要高性能但又不想增加过多协议复杂性的应用程序。Hessian是一种小型的二进制协议,它专注于数据的高效传输,而Burlap则是一种匹配的XML协议,提供了一...
本文主要探讨了Java领域中常见的几种远程通讯技术,包括RMI、MINA、ESB、Burlap、Hessian、SOAP、EJB和JMS等。这些技术各有特点,适用于不同的场景。 **RMI(Remote Method Invocation)** RMI是Java平台特有的一种...
远程调用方法就是HttpInvoker:他也是将参数和返回值通过Java的序列化机制进行编组和反编组,它具有RMI的支持所有可序列化对象的...试使用Http协议传输二进制流的,同时又具有Hessian、Burlap(传输xml文本)的优点。
在Burlap项目中,这里会包含你的业务逻辑代码、Burlap服务接口实现、以及其他与网络通信相关的类。确保正确地组织代码结构有助于提高代码的可读性和维护性。 `.settings`目录存储的是项目的IDE特定设置,比如...
burlap-2.1.12.jar
4. **Hessian和Burlap**:是Apache的Caucho项目提供的二进制RPC协议,它们提供了一种轻量级的序列化方式,适合于内部服务间的通信,尤其是跨语言通信。 在Netty中实现序列化,通常需要自定义`MessageToByteEncoder`...
标题与描述中提到的主题是“基于Spring的远程访问与Web Service”,这涉及到Spring框架在企业级应用中的关键特性——即其支持多种远程服务调用的方式,包括但不限于RMI、HTTP Invoker、Hessian、Burlap、JAX-RPC以及...
Hessian和Burlap是二进制和文本的RPC协议,它们提供了轻量级的远程调用解决方案,适合对性能要求较高的场景。 JMS(Java Message Service)是Java平台的消息队列标准,它允许应用程序之间异步发送和接收消息,适用...
7. JMS:远程访问通过类JmsInvokerServiceExporter和JmsInvokerProxyFactoryBean使用JMS的底层协议实现。 二. 远程访问------RMI 1. RMI远程访问基本流程 1). 服务端定义远程访问接口; 2). 服务端通过...
3. Hessian和Burlap:这两种协议是基于HTTP的轻量级二进制协议,它们提供了更高效的序列化机制。Hessian是二进制的,而Burlap是基于XML的,两者都提供了自动类型转换的能力,使得跨语言调用成为可能。 4. JMS(Java...
jar包,亲测可用
- Hessian和Burlap:基于HTTP协议的远程通信技术,用于序列化Java对象。 - EJB(Enterprise JavaBeans):一种用于开发企业级应用的Java组件架构,支持远程通信。 6. 网络协议与Java远程通信的关系: - TCP/UDP...
这些接口在服务端实现,客户端通过AMQP协议调用。 6. **Message Converters**: 为了将Java对象与AMQP消息之间进行转换,Spring-Remoting-AMQP提供了消息转换器,确保请求和响应能正确地序列化和反序列化。 通过...
Mastering Resin (英文版) by Richard Hightower and Joseph D. Gradecki ISBN:0471431036 ... Appendix D - Burlap and Hessian APIs Index List of Figures List of Tables List of Listings
Java领域中有多种实现远程通讯的技术,如RMI(Remote Method Invocation)、MINA(Multi-purpose Infrastructure for Network Applications)、ESB(Enterprise Service Bus)、Burlap、Hessian、SOAP(Simple ...