src/java.rmi/share/classes/java/rmi/registry/LocateRegistry.java
changeset 47216 71c04702a3d5
parent 28059 e576535359cc
equal deleted inserted replaced
47215:4ebc2e2fb97c 47216:71c04702a3d5
       
     1 /*
       
     2  * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved.
       
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
       
     4  *
       
     5  * This code is free software; you can redistribute it and/or modify it
       
     6  * under the terms of the GNU General Public License version 2 only, as
       
     7  * published by the Free Software Foundation.  Oracle designates this
       
     8  * particular file as subject to the "Classpath" exception as provided
       
     9  * by Oracle in the LICENSE file that accompanied this code.
       
    10  *
       
    11  * This code is distributed in the hope that it will be useful, but WITHOUT
       
    12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
       
    13  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
       
    14  * version 2 for more details (a copy is included in the LICENSE file that
       
    15  * accompanied this code).
       
    16  *
       
    17  * You should have received a copy of the GNU General Public License version
       
    18  * 2 along with this work; if not, write to the Free Software Foundation,
       
    19  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
       
    20  *
       
    21  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
       
    22  * or visit www.oracle.com if you need additional information or have any
       
    23  * questions.
       
    24  */
       
    25 
       
    26 package java.rmi.registry;
       
    27 
       
    28 import java.rmi.RemoteException;
       
    29 import java.rmi.server.ObjID;
       
    30 import java.rmi.server.RMIClientSocketFactory;
       
    31 import java.rmi.server.RMIServerSocketFactory;
       
    32 import java.rmi.server.RemoteRef;
       
    33 import java.rmi.server.UnicastRemoteObject;
       
    34 import sun.rmi.registry.RegistryImpl;
       
    35 import sun.rmi.server.UnicastRef2;
       
    36 import sun.rmi.server.UnicastRef;
       
    37 import sun.rmi.server.Util;
       
    38 import sun.rmi.transport.LiveRef;
       
    39 import sun.rmi.transport.tcp.TCPEndpoint;
       
    40 
       
    41 /**
       
    42  * <code>LocateRegistry</code> is used to obtain a reference to a bootstrap
       
    43  * remote object registry on a particular host (including the local host), or
       
    44  * to create a remote object registry that accepts calls on a specific port.
       
    45  *
       
    46  * <p> Note that a <code>getRegistry</code> call does not actually make a
       
    47  * connection to the remote host.  It simply creates a local reference to
       
    48  * the remote registry and will succeed even if no registry is running on
       
    49  * the remote host.  Therefore, a subsequent method invocation to a remote
       
    50  * registry returned as a result of this method may fail.
       
    51  *
       
    52  * @author  Ann Wollrath
       
    53  * @author  Peter Jones
       
    54  * @since   1.1
       
    55  * @see     java.rmi.registry.Registry
       
    56  */
       
    57 public final class LocateRegistry {
       
    58 
       
    59     /**
       
    60      * Private constructor to disable public construction.
       
    61      */
       
    62     private LocateRegistry() {}
       
    63 
       
    64     /**
       
    65      * Returns a reference to the remote object <code>Registry</code> for
       
    66      * the local host on the default registry port of 1099.
       
    67      *
       
    68      * @return reference (a stub) to the remote object registry
       
    69      * @exception RemoteException if the reference could not be created
       
    70      * @since 1.1
       
    71      */
       
    72     public static Registry getRegistry()
       
    73         throws RemoteException
       
    74     {
       
    75         return getRegistry(null, Registry.REGISTRY_PORT);
       
    76     }
       
    77 
       
    78     /**
       
    79      * Returns a reference to the remote object <code>Registry</code> for
       
    80      * the local host on the specified <code>port</code>.
       
    81      *
       
    82      * @param port port on which the registry accepts requests
       
    83      * @return reference (a stub) to the remote object registry
       
    84      * @exception RemoteException if the reference could not be created
       
    85      * @since 1.1
       
    86      */
       
    87     public static Registry getRegistry(int port)
       
    88         throws RemoteException
       
    89     {
       
    90         return getRegistry(null, port);
       
    91     }
       
    92 
       
    93     /**
       
    94      * Returns a reference to the remote object <code>Registry</code> on the
       
    95      * specified <code>host</code> on the default registry port of 1099.  If
       
    96      * <code>host</code> is <code>null</code>, the local host is used.
       
    97      *
       
    98      * @param host host for the remote registry
       
    99      * @return reference (a stub) to the remote object registry
       
   100      * @exception RemoteException if the reference could not be created
       
   101      * @since 1.1
       
   102      */
       
   103     public static Registry getRegistry(String host)
       
   104         throws RemoteException
       
   105     {
       
   106         return getRegistry(host, Registry.REGISTRY_PORT);
       
   107     }
       
   108 
       
   109     /**
       
   110      * Returns a reference to the remote object <code>Registry</code> on the
       
   111      * specified <code>host</code> and <code>port</code>. If <code>host</code>
       
   112      * is <code>null</code>, the local host is used.
       
   113      *
       
   114      * @param host host for the remote registry
       
   115      * @param port port on which the registry accepts requests
       
   116      * @return reference (a stub) to the remote object registry
       
   117      * @exception RemoteException if the reference could not be created
       
   118      * @since 1.1
       
   119      */
       
   120     public static Registry getRegistry(String host, int port)
       
   121         throws RemoteException
       
   122     {
       
   123         return getRegistry(host, port, null);
       
   124     }
       
   125 
       
   126     /**
       
   127      * Returns a locally created remote reference to the remote object
       
   128      * <code>Registry</code> on the specified <code>host</code> and
       
   129      * <code>port</code>.  Communication with this remote registry will
       
   130      * use the supplied <code>RMIClientSocketFactory</code> <code>csf</code>
       
   131      * to create <code>Socket</code> connections to the registry on the
       
   132      * remote <code>host</code> and <code>port</code>.
       
   133      *
       
   134      * @param host host for the remote registry
       
   135      * @param port port on which the registry accepts requests
       
   136      * @param csf  client-side <code>Socket</code> factory used to
       
   137      *      make connections to the registry.  If <code>csf</code>
       
   138      *      is null, then the default client-side <code>Socket</code>
       
   139      *      factory will be used in the registry stub.
       
   140      * @return reference (a stub) to the remote registry
       
   141      * @exception RemoteException if the reference could not be created
       
   142      * @since 1.2
       
   143      */
       
   144     public static Registry getRegistry(String host, int port,
       
   145                                        RMIClientSocketFactory csf)
       
   146         throws RemoteException
       
   147     {
       
   148         Registry registry = null;
       
   149 
       
   150         if (port <= 0)
       
   151             port = Registry.REGISTRY_PORT;
       
   152 
       
   153         if (host == null || host.length() == 0) {
       
   154             // If host is blank (as returned by "file:" URL in 1.0.2 used in
       
   155             // java.rmi.Naming), try to convert to real local host name so
       
   156             // that the RegistryImpl's checkAccess will not fail.
       
   157             try {
       
   158                 host = java.net.InetAddress.getLocalHost().getHostAddress();
       
   159             } catch (Exception e) {
       
   160                 // If that failed, at least try "" (localhost) anyway...
       
   161                 host = "";
       
   162             }
       
   163         }
       
   164 
       
   165         /*
       
   166          * Create a proxy for the registry with the given host, port, and
       
   167          * client socket factory.  If the supplied client socket factory is
       
   168          * null, then the ref type is a UnicastRef, otherwise the ref type
       
   169          * is a UnicastRef2.  If the property
       
   170          * java.rmi.server.ignoreStubClasses is true, then the proxy
       
   171          * returned is an instance of a dynamic proxy class that implements
       
   172          * the Registry interface; otherwise the proxy returned is an
       
   173          * instance of the pregenerated stub class for RegistryImpl.
       
   174          **/
       
   175         LiveRef liveRef =
       
   176             new LiveRef(new ObjID(ObjID.REGISTRY_ID),
       
   177                         new TCPEndpoint(host, port, csf, null),
       
   178                         false);
       
   179         RemoteRef ref =
       
   180             (csf == null) ? new UnicastRef(liveRef) : new UnicastRef2(liveRef);
       
   181 
       
   182         return (Registry) Util.createProxy(RegistryImpl.class, ref, false);
       
   183     }
       
   184 
       
   185     /**
       
   186      * Creates and exports a <code>Registry</code> instance on the local
       
   187      * host that accepts requests on the specified <code>port</code>.
       
   188      *
       
   189      * <p>The <code>Registry</code> instance is exported as if the static
       
   190      * {@link UnicastRemoteObject#exportObject(Remote,int)
       
   191      * UnicastRemoteObject.exportObject} method is invoked, passing the
       
   192      * <code>Registry</code> instance and the specified <code>port</code> as
       
   193      * arguments, except that the <code>Registry</code> instance is
       
   194      * exported with a well-known object identifier, an {@link ObjID}
       
   195      * instance constructed with the value {@link ObjID#REGISTRY_ID}.
       
   196      *
       
   197      * @param port the port on which the registry accepts requests
       
   198      * @return the registry
       
   199      * @exception RemoteException if the registry could not be exported
       
   200      * @since 1.1
       
   201      **/
       
   202     public static Registry createRegistry(int port) throws RemoteException {
       
   203         return new RegistryImpl(port);
       
   204     }
       
   205 
       
   206     /**
       
   207      * Creates and exports a <code>Registry</code> instance on the local
       
   208      * host that uses custom socket factories for communication with that
       
   209      * instance.  The registry that is created listens for incoming
       
   210      * requests on the given <code>port</code> using a
       
   211      * <code>ServerSocket</code> created from the supplied
       
   212      * <code>RMIServerSocketFactory</code>.
       
   213      *
       
   214      * <p>The <code>Registry</code> instance is exported as if
       
   215      * the static {@link
       
   216      * UnicastRemoteObject#exportObject(Remote,int,RMIClientSocketFactory,RMIServerSocketFactory)
       
   217      * UnicastRemoteObject.exportObject} method is invoked, passing the
       
   218      * <code>Registry</code> instance, the specified <code>port</code>, the
       
   219      * specified <code>RMIClientSocketFactory</code>, and the specified
       
   220      * <code>RMIServerSocketFactory</code> as arguments, except that the
       
   221      * <code>Registry</code> instance is exported with a well-known object
       
   222      * identifier, an {@link ObjID} instance constructed with the value
       
   223      * {@link ObjID#REGISTRY_ID}.
       
   224      *
       
   225      * @param port port on which the registry accepts requests
       
   226      * @param csf  client-side <code>Socket</code> factory used to
       
   227      *      make connections to the registry
       
   228      * @param ssf  server-side <code>ServerSocket</code> factory
       
   229      *      used to accept connections to the registry
       
   230      * @return the registry
       
   231      * @exception RemoteException if the registry could not be exported
       
   232      * @since 1.2
       
   233      **/
       
   234     public static Registry createRegistry(int port,
       
   235                                           RMIClientSocketFactory csf,
       
   236                                           RMIServerSocketFactory ssf)
       
   237         throws RemoteException
       
   238     {
       
   239         return new RegistryImpl(port, csf, ssf);
       
   240     }
       
   241 }