package.html 5.5 KB
Newer Older
D
duke 已提交
1 2 3 4
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<html>
<head>
<!--
5
Copyright (c) 1999, 2006, Oracle and/or its affiliates. All rights reserved.
D
duke 已提交
6 7 8 9
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

This code is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License version 2 only, as
10
published by the Free Software Foundation.  Oracle designates this
D
duke 已提交
11
particular file as subject to the "Classpath" exception as provided
12
by Oracle in the LICENSE file that accompanied this code.
D
duke 已提交
13 14 15 16 17 18 19 20 21 22 23

This code 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.  See the GNU General Public License
version 2 for more details (a copy is included in the LICENSE file that
accompanied this code).

You should have received a copy of the GNU General Public License version
2 along with this work; if not, write to the Free Software Foundation,
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.

24 25 26
Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
or visit www.oracle.com if you need additional information or have any
questions.
D
duke 已提交
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
-->
</head>
<body bgcolor="white">

Provides the classes and interfaces for accessing naming services.

<p>
This package defines the naming operations of the Java Naming and
Directory Interface<font size=-2><sup>TM</sup></font> (JNDI). &nbsp;
JNDI provides naming and directory functionality to applications
written in the Java programming language.  It is designed to be
independent of any specific naming or directory service
implementation.  Thus a variety of services--new, emerging, and
already deployed ones--can be accessed in a common way.


<h4>Context</h4>
<p>
This package defines the notion of a <em>context</em>, represented
by the <tt>Context</tt> interface.
A context consists of a set of name-to-object <em>bindings</em>.
<tt>Context</tt> is the core interface for looking up, binding, unbinding, 
and renaming objects, and for creating and destroying subcontexts.
<p>
<tt>lookup()</tt> is the most commonly used operation.
You supply <tt>lookup()</tt>
the name of the object you want
to look up, and it returns the object bound to that name.
For example, the following code fragment looks up 
a printer and sends a document to the printer object
to be printed:

<blockquote>
<pre>
Printer printer = (Printer)ctx.lookup("treekiller");
printer.print(report);
</pre>
</blockquote>

<h4>Names</h4>
<p>
Every naming method in the <tt>Context</tt>
interface has two
overloads: one that accepts a 
<tt>Name</tt> argument and one that accepts a string name.
<tt>Name</tt> is an interface that represents a generic 
name--an ordered sequence of zero of more components.
For these methods, <tt>Name</tt> can be used to represent a
<em>composite name</em> (<tt>CompositeName</tt>)
so that you can name an object using a name which spans multiple namespaces.
<p>
The overloads that accept <tt>Name</tt>
are useful for applications that need to manipulate names: composing
them, comparing components, and so on.
The overloads that accept string names are likely to be more useful
for simple applications, such as those that simply read in a name
and look up the corresponding object.
<p>

<h4>Bindings</h4>

The <tt>Binding</tt> class represents a name-to-object binding.
It is a tuple containing the name of the bound object,
the name of the object's class, and the object itself.
<p>
The <tt>Binding</tt> class is actually a subclass of
<tt>NameClassPair</tt>, which consists
simply of the object's name and the object's class name.
The <tt>NameClassPair</tt> is useful when you only want
information about the object's class and do not want to
pay the extra cost of getting the object.

<h4>References</h4>
Objects are stored in naming and directory services in different ways.
If an object store supports storing Java objects, 
it might support storing an object in its serialized form.
However, some naming and directory services do not support the
storing of Java objects. Furthermore, for some
objects in the directory, Java programs are but one group of applications 
that access them. In this case, a serialized Java object might
not be the most appropriate representation.
JNDI defines a <em>reference</em>, represented by the <tt>Reference</tt>
class, which contains information on how to construct a copy of the object.
JNDI will attempt to turn references looked up from the directory
into the Java objects they represent, so that
JNDI clients have the illusion that what
is stored in the directory are Java objects. 


<h4>The Initial Context</h4>

In JNDI, all naming and directory operations are performed relative
to a context. There are no absolute roots.
Therefore JNDI defines an <em>initial context</em>, 
<tt>InitialContext</tt>,
which provides a starting point for naming and directory operations.
Once you have an initial context, you can use it to
look up other contexts and objects.

<h4>Exceptions</h4>

JNDI defines a class hierarchy for exceptions that can be thrown in
the course of performing naming and directory operations.  The root of
this class hierarchy is <tt>NamingException</tt>.
Programs interested in dealing with a particular exception
can catch the corresponding subclass of the exception.
Otherwise, programs should catch <tt>NamingException</tt>.


<h2>Package Specification</h2>

The JNDI API Specification and related documents can be found in the
<a href="../../../technotes/guides/jndi/index.html">JNDI documentation</a>.

@since 1.3

</body>
</html>