`
longgangbai
  • 浏览: 7371288 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Burlap中hessian协议研究(六)协议的服务端骨架的实现

阅读更多

响应的服务端骨架类:

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-spring-demo

    Burlap是一个轻量级的XML RPC协议 这使得他可以移植到任何可以解析XML的语言中 比起Hessian 它的可读性更强 和其他基于Xml的远程技术(如SOAP和XML RPC)不同 它的消息结构尽可能简单 不需要额外的外部定义语言 如...

    Spring配置hessian远程服务

    使用eclipse maven工程搭建hessian远程服务demo 分服务端的整合和客户端 建议阅读相关博客http://blog.csdn.net/heisemuyangquan/article/details/79460528

    闲着没事Hessian开发WebService的总结(一)

    然后,他可能会讲述如何在Java环境中设置Hessian服务,包括添加依赖库、创建服务接口和服务实现、配置服务器和客户端。此外,还可能涉及到如何使用Hessian的Binder来暴露和调用服务。 对于Burlap,作者可能会对比...

    hessian java +c# 数据测试

    至于"List"和"Map",它们在Hessian中也有特别的处理方式。Hessian可以序列化和反序列化List和Map类型的集合,无论是基本类型还是自定义对象的集合。在Java端,`List`和`Map`会被转换成Hessian的特定格式,而在C#端,...

    Hessian 接口 Java Python.docx

    Hessian和Burlap是两种高效且简洁的网络通信协议,尤其适用于需要高性能但又不想增加过多协议复杂性的应用程序。Hessian是一种小型的二进制协议,它专注于数据的高效传输,而Burlap则是一种匹配的XML协议,提供了一...

    Java远程通讯可选技术及原理.docx

    本文主要探讨了Java领域中常见的几种远程通讯技术,包括RMI、MINA、ESB、Burlap、Hessian、SOAP、EJB和JMS等。这些技术各有特点,适用于不同的场景。 **RMI(Remote Method Invocation)** RMI是Java平台特有的一种...

    hessian 实例

    远程调用方法就是HttpInvoker:他也是将参数和返回值通过Java的序列化机制进行编组和反编组,它具有RMI的支持所有可序列化对象的...试使用Http协议传输二进制流的,同时又具有Hessian、Burlap(传输xml文本)的优点。

    Burlap开发学习

    在Burlap项目中,这里会包含你的业务逻辑代码、Burlap服务接口实现、以及其他与网络通信相关的类。确保正确地组织代码结构有助于提高代码的可读性和维护性。 `.settings`目录存储的是项目的IDE特定设置,比如...

    burlap-2.1.12.jar

    burlap-2.1.12.jar

    Netty之序列化协议

    4. **Hessian和Burlap**:是Apache的Caucho项目提供的二进制RPC协议,它们提供了一种轻量级的序列化方式,适合于内部服务间的通信,尤其是跨语言通信。 在Netty中实现序列化,通常需要自定义`MessageToByteEncoder`...

    基于Spring的远程访问与Web Service

    标题与描述中提到的主题是“基于Spring的远程访问与Web Service”,这涉及到Spring框架在企业级应用中的关键特性——即其支持多种远程服务调用的方式,包括但不限于RMI、HTTP Invoker、Hessian、Burlap、JAX-RPC以及...

    Java远程通讯可选技术及原理

    Hessian和Burlap是二进制和文本的RPC协议,它们提供了轻量级的远程调用解决方案,适合对性能要求较高的场景。 JMS(Java Message Service)是Java平台的消息队列标准,它允许应用程序之间异步发送和接收消息,适用...

    Spring 实现远程访问详解——rmi

    7. JMS:远程访问通过类JmsInvokerServiceExporter和JmsInvokerProxyFactoryBean使用JMS的底层协议实现。 二. 远程访问------RMI 1. RMI远程访问基本流程 1). 服务端定义远程访问接口; 2). 服务端通过...

    spring remoting

    3. Hessian和Burlap:这两种协议是基于HTTP的轻量级二进制协议,它们提供了更高效的序列化机制。Hessian是二进制的,而Burlap是基于XML的,两者都提供了自动类型转换的能力,使得跨语言调用成为可能。 4. JMS(Java...

    burlap-2.1.7.jar

    jar包,亲测可用

    Java远程技术.pdf

    - Hessian和Burlap:基于HTTP协议的远程通信技术,用于序列化Java对象。 - EJB(Enterprise JavaBeans):一种用于开发企业级应用的Java组件架构,支持远程通信。 6. 网络协议与Java远程通信的关系: - TCP/UDP...

    org.jflux.impl.transport.qpid-0.1.4.zip

    这些接口在服务端实现,客户端通过AMQP协议调用。 6. **Message Converters**: 为了将Java对象与AMQP消息之间进行转换,Spring-Remoting-AMQP提供了消息转换器,确保请求和响应能正确地序列化和反序列化。 通过...

    Mastering+Resin.rar

    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

    远程调用的几种方式.pdf

    Java领域中有多种实现远程通讯的技术,如RMI(Remote Method Invocation)、MINA(Multi-purpose Infrastructure for Network Applications)、ESB(Enterprise Service Bus)、Burlap、Hessian、SOAP(Simple ...

Global site tag (gtag.js) - Google Analytics