FileDocCategorySizeDatePackage
AccountServer.javaAPI DocExample2560Thu Dec 15 21:45:10 GMT 2005com.oreilly.jent.rmi

AccountServer.java

package com.oreilly.jent.rmi;

/**
 * In general, you may use the code in this book in your programs and 
 * documentation. You do not need to contact us for permission unless 
 * you're reproducing a significant portion of the code. For example, 
 * writing a program that uses several chunks of code from this book does 
 * not require permission. Selling or distributing a CD-ROM of examples 
 * from O'Reilly books does require permission. Answering a question by 
 * citing this book and quoting example code does not require permission. 
 * Incorporating a significant amount of example code from this book into 
 * your product's documentation does require permission.
 * 
 * We appreciate, but do not require, attribution. An attribution usually 
 * includes the title, author, publisher, and ISBN. For example: 
 * 
 *   "Java Enterprise in a Nutshell, Third Edition, 
 *    by Jim Farley and William Crawford 
 *    with Prakash Malani, John G. Norman, and Justin Gehtland. 
 *    Copyright 2006 O'Reilly Media, Inc., 0-596-10142-2."
 *  
 *  If you feel your use of code examples falls outside fair use or the 
 *  permission given above, feel free to contact us at 
 *  permissions@oreilly.com.
 */

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RMISecurityManager;
import java.rmi.RemoteException;

/**
 * AccountServer: A utility class that registers an Account with the local
 * RMI registry for remote access
 */

public class AccountServer {
    public static void main(String argv[]) {
        try {
            System.setSecurityManager(new RMISecurityManager());
            // Make an Account with a given name
            AccountImpl acct = new AccountImpl("JimF");
            
            // Register it with the local naming registry
            Naming.rebind("JimF", acct);
            System.out.println("Registered account as JimF.");
            
            // Keep the server process alive indefinitely
            Object dummy = new Object();
            synchronized (dummy) {
                try {
                    dummy.wait();
                }
                catch (InterruptedException ie) {}
            }
        }
        catch (RemoteException re) {
            System.err.println("Remote exception while creating/registering: "
                               + re.getMessage());
        }
        catch (MalformedURLException mue) {
            System.err.println("Bad name given when binding server object: "
                               + mue.getMessage());
        }
    }
}