Save This Page
Home » glassfish-v2ur2-b04-src » javax » mail » [javadoc | source]
javax.mail
public final class: Session [javadoc | source]
java.lang.Object
   javax.mail.Session
The Session class represents a mail session and is not subclassed. It collects together properties and defaults used by the mail API's. A single default session can be shared by multiple applications on the desktop. Unshared sessions can also be created.

The Session class provides access to the protocol providers that implement the Store, Transport, and related classes. The protocol providers are configured using the following files:

Each javamail.X resource file is searched for using three methods in the following order:

  1. java.home/lib/javamail.X
  2. META-INF/javamail.X
  3. META-INF/javamail.default.X

The first method allows the user to include their own version of the resource file by placing it in the lib directory where the java.home property points. The second method allows an application that uses the JavaMail APIs to include their own resource files in their application's or jar file's META-INF directory. The javamail.default.X default files are part of the JavaMail mail.jar file.

File location depends upon how the ClassLoader method getResource is implemented. Usually, the getResource method searches through CLASSPATH until it finds the requested file and then stops. JDK 1.1 has a limitation that the number of files of each name that will be found in the CLASSPATH is limited to one. However, this only affects method two, above; method one is loaded from a specific location (if allowed by the SecurityManager) and method three uses a different name to ensure that the default resource file is always loaded successfully. J2SE 1.2 and later are not limited to one file of a given name.

The ordering of entries in the resource files matters. If multiple entries exist, the first entries take precedence over the later entries. For example, the first IMAP provider found will be set as the default IMAP implementation until explicitly changed by the application. The user- or system-supplied resource files augment, they do not override, the default files included with the JavaMail APIs. This means that all entries in all files loaded will be available.

javamail.providers and javamail.default.providers

These resource files specify the stores and transports that are available on the system, allowing an application to "discover" what store and transport implementations are available. The protocol implementations are listed one per line. The file format defines four attributes that describe a protocol implementation. Each attribute is an "="-separated name-value pair with the name in lowercase. Each name-value pair is semi-colon (";") separated. The following names are defined.

Attribute Names in Providers Files
NameDescription
protocol Name assigned to protocol. For example, smtp for Transport.
type Valid entries are store and transport.
class Class name that implements this protocol.
vendor Optional string identifying the vendor.
version Optional string identifying the version.

Here's an example of META-INF/javamail.default.providers file contents:

protocol=imap; type=store; class=com.sun.mail.imap.IMAPStore; vendor=Sun Microsystems, Inc.;
protocol=smtp; type=transport; class=com.sun.mail.smtp.SMTPTransport; vendor=Sun Microsystems, Inc.;

javamail.address.map and javamail.default.address.map

These resource files map transport address types to the transport protocol. The getType method of javax.mail.Address returns the address type. The javamail.address.map file maps the transport type to the protocol. The file format is a series of name-value pairs. Each key name should correspond to an address type that is currently installed on the system; there should also be an entry for each javax.mail.Address implementation that is present if it is to be used. For example, the javax.mail.internet.InternetAddress method getType returns "rfc822". Each referenced protocol should be installed on the system. For the case of news, below, the client should install a Transport provider supporting the nntp protocol.

Here are the typical contents of a javamail.address.map file:

rfc822=smtp
news=nntp
Method from javax.mail.Session Summary:
addProvider,   getDebug,   getDebugOut,   getDefaultInstance,   getDefaultInstance,   getFolder,   getInstance,   getInstance,   getPasswordAuthentication,   getProperties,   getProperty,   getProvider,   getProviders,   getStore,   getStore,   getStore,   getStore,   getTransport,   getTransport,   getTransport,   getTransport,   getTransport,   requestPasswordAuthentication,   setDebug,   setDebugOut,   setPasswordAuthentication,   setProtocolForAddress,   setProvider
Methods from java.lang.Object:
equals,   getClass,   hashCode,   notify,   notifyAll,   toString,   wait,   wait,   wait
Method from javax.mail.Session Detail:
 public synchronized  void addProvider(Provider provider) 
    Add a provider to the session.
 public synchronized boolean getDebug() 
    Get the debug setting for this Session.
 public synchronized PrintStream getDebugOut() 
    Returns the stream to be used for debugging output. If no stream has been set, System.out is returned.
 public static Session getDefaultInstance(Properties props) 
    Get the default Session object. If a default has not yet been setup, a new Session object is created and installed as the default.

    Note that a default session created with no Authenticator is available to all code executing in the same Java virtual machine, and the session can contain security sensitive information such as user names and passwords.

 public static synchronized Session getDefaultInstance(Properties props,
    Authenticator authenticator) 
    Get the default Session object. If a default has not yet been setup, a new Session object is created and installed as the default.

    Since the default session is potentially available to all code executing in the same Java virtual machine, and the session can contain security sensitive information such as user names and passwords, access to the default session is restricted. The Authenticator object, which must be created by the caller, is used indirectly to check access permission. The Authenticator object passed in when the session is created is compared with the Authenticator object passed in to subsequent requests to get the default session. If both objects are the same, or are from the same ClassLoader, the request is allowed. Otherwise, it is denied.

    Note that if the Authenticator object used to create the session is null, anyone can get the default session by passing in null.

    Note also that the Properties object is used only the first time this method is called, when a new Session object is created. Subsequent calls return the Session object that was created by the first call, and ignore the passed Properties object. Use the getInstance method to get a new Session object every time the method is called.

    In JDK 1.2, additional security Permission objects may be used to control access to the default session.

 public Folder getFolder(URLName url) throws MessagingException 
    Get a closed Folder object for the given URLName. If the requested Folder object cannot be obtained, null is returned.

    The "scheme" part of the URL string (Refer RFC 1738) is used to locate the Store protocol. The rest of the URL string (that is, the "schemepart", as per RFC 1738) is used by that Store in a protocol dependent manner to locate and instantiate the appropriate Folder object.

    Note that RFC 1738 also specifies the syntax for the "schemepart" for IP-based protocols (IMAP4, POP3, etc.). Providers of IP-based mail Stores should implement that syntax for referring to Folders.

 public static Session getInstance(Properties props) 
    Get a new Session object.
 public static Session getInstance(Properties props,
    Authenticator authenticator) 
    Get a new Session object.
 public PasswordAuthentication getPasswordAuthentication(URLName url) 
    Return any saved PasswordAuthentication for this (store or transport) URLName. Normally used only by store or transport implementations.
 public Properties getProperties() 
    Returns the Properties object associated with this Session
 public String getProperty(String name) 
    Returns the value of the specified property. Returns null if this property does not exist.
 public synchronized Provider getProvider(String protocol) throws NoSuchProviderException 
    Returns the default Provider for the protocol specified. Checks mail.<protocol>.class property first and if it exists, returns the Provider associated with this implementation. If it doesn't exist, returns the Provider that appeared first in the configuration files. If an implementation for the protocol isn't found, throws NoSuchProviderException
 public synchronized Provider[] getProviders() 
    This method returns an array of all the implementations installed via the javamail.[default.]providers files that can be loaded using the ClassLoader available to this application.
 public Store getStore() throws NoSuchProviderException 
    Get a Store object that implements this user's desired Store protocol. The mail.store.protocol property specifies the desired protocol. If an appropriate Store object is not obtained, NoSuchProviderException is thrown
 public Store getStore(String protocol) throws NoSuchProviderException 
    Get a Store object that implements the specified protocol. If an appropriate Store object cannot be obtained, NoSuchProviderException is thrown.
 public Store getStore(URLName url) throws NoSuchProviderException 
    Get a Store object for the given URLName. If the requested Store object cannot be obtained, NoSuchProviderException is thrown. The "scheme" part of the URL string (Refer RFC 1738) is used to locate the Store protocol.

 public Store getStore(Provider provider) throws NoSuchProviderException 
    Get an instance of the store specified by Provider. Instantiates the store and returns it.
 public Transport getTransport() throws NoSuchProviderException 
    Get a Transport object that implements this user's desired Transport protcol. The mail.transport.protocol property specifies the desired protocol. If an appropriate Transport object cannot be obtained, MessagingException is thrown.
 public Transport getTransport(String protocol) throws NoSuchProviderException 
    Get a Transport object that implements the specified protocol. If an appropriate Transport object cannot be obtained, null is returned.
 public Transport getTransport(URLName url) throws NoSuchProviderException 
    Get a Transport object for the given URLName. If the requested Transport object cannot be obtained, NoSuchProviderException is thrown. The "scheme" part of the URL string (Refer RFC 1738) is used to locate the Transport protocol.

 public Transport getTransport(Provider provider) throws NoSuchProviderException 
    Get an instance of the transport specified in the Provider. Instantiates the transport and returns it.
 public Transport getTransport(Address address) throws NoSuchProviderException 
    Get a Transport object that can transport a Message to the specified address type.
 public PasswordAuthentication requestPasswordAuthentication(InetAddress addr,
    int port,
    String protocol,
    String prompt,
    String defaultUserName) 
    Call back to the application to get the needed user name and password. The application should put up a dialog something like:

    Connecting to <protocol> mail service on host <addr>, port <port>.
    <prompt>
    
    User Name: <defaultUserName>
    Password:
    
 public synchronized  void setDebug(boolean debug) 
    Set the debug setting for this Session.

    Since the debug setting can be turned on only after the Session has been created, to turn on debugging in the Session constructor, set the property mail.debug in the Properties object passed in to the constructor to true. The value of the mail.debug property is used to initialize the per-Session debugging flag. Subsequent calls to the setDebug method manipulate the per-Session debugging flag and have no affect on the mail.debug property.

 public synchronized  void setDebugOut(PrintStream out) 
    Set the stream to be used for debugging output for this session. If out is null, System.out will be used. Note that debugging output that occurs before any session is created, as a result of setting the mail.debug system property, will always be sent to System.out.
 public  void setPasswordAuthentication(URLName url,
    PasswordAuthentication pw) 
    Save a PasswordAuthentication for this (store or transport) URLName. If pw is null the entry corresponding to the URLName is removed.

    This is normally used only by the store or transport implementations to allow authentication information to be shared among multiple uses of a session.

 public synchronized  void setProtocolForAddress(String addresstype,
    String protocol) 
    Set the default transport protocol to use for addresses of the specified type. Normally the default is set by the javamail.default.address.map or javamail.address.map files or resources.
 public synchronized  void setProvider(Provider provider) throws NoSuchProviderException 
    Set the passed Provider to be the default implementation for the protocol in Provider.protocol overriding any previous values.