hessianstubfactory.java

来自「RESIN 3.2 最新源码」· Java 代码 · 共 146 行

JAVA
146
字号
/* * Copyright (c) 1998-2008 Caucho Technology -- all rights reserved * * This file is part of Resin(R) Open Source * * Each copy or derived work must preserve the copyright notice and this * notice unmodified. * * Resin Open Source is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * Resin Open Source is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty * of NON-INFRINGEMENT.  See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with Resin Open Source; if not, write to the *   Free SoftwareFoundation, Inc. *   59 Temple Place, Suite 330 *   Boston, MA 02111-1307  USA * * @@author Scott Ferguson */package com.caucho.ejb.hessian;import com.caucho.java.WorkDir;import com.caucho.hessian.io.AbstractHessianInput;import com.caucho.hessian.io.HessianOutput;import com.caucho.hessian.io.HessianRemoteResolver;import com.caucho.hessian.io.HessianSerializerInput;import com.caucho.server.util.CauchoSystem;import com.caucho.vfs.Path;import com.caucho.vfs.Vfs;import java.io.IOException;import java.io.InputStream;import java.io.OutputStream;/** * Factory for creating Hessian client stubs.  The returned stub will * call the remote object for all methods. * * <pre> * String url = "http://localhost:8080/ejb/hello"; * HelloHome hello = (HelloHome) factory.create(HelloHome.class, url); * </pre> * * After creation, the stub can be like a regular Java class.  Because * it makes remote calls, it can throw more exceptions than a Java class. * In particular, it may throw protocol exceptions. */public class HessianStubFactory implements HessianRemoteResolver {  private HessianRemoteResolver _resolver;  private Path _workPath;    public HessianStubFactory()  {    _resolver = this;  }  /**   * Returns the remote resolver.   */  public HessianRemoteResolver getRemoteResolver()  {    return _resolver;  }  public void setWorkPath(Path path)  {    _workPath = path;  }  public Path getWorkPath()  {    if (_workPath != null)      return _workPath;    else      return WorkDir.getLocalWorkDir();  }  /**   * Creates a new proxy with the specified URL.  The returned object   * is a proxy with the interface specified by api.   *   * <pre>   * String url = "http://localhost:8080/ejb/hello");   * HelloHome hello = (HelloHome) factory.create(HelloHome.class, url);   * </pre>   *   * @@param api the interface the proxy class needs to implement   * @@param url the URL where the client object is located.   *   * @@return a proxy to the object with the specified interface.   */  public Object create(Class api, String url)    throws Exception  {    StubGenerator gen = new StubGenerator();    gen.setClassDir(getWorkPath().lookup("ejb"));          Class cl = gen.createStub(api);    HessianStub stub = (HessianStub) cl.newInstance();    stub._hessian_setURLPath(Vfs.lookup(url));    stub._hessian_setClientContainer(this);    return stub;  }  public AbstractHessianInput getHessianInput(InputStream is)  {    AbstractHessianInput in = new HessianSerializerInput(is);    in.setRemoteResolver(_resolver);    return in;  }  public HessianOutput getHessianOutput(OutputStream os)  {    return new HessianWriter(os);  }    /**   * Looks up a proxy object.   */  public Object lookup(String type, String url)    throws IOException  {    try {      Class api = CauchoSystem.loadClass(type);      return create(api, url);    } catch (Exception e) {      throw new IOException(String.valueOf(e));    }  }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?