public class JavaMailSenderImpl extends java.lang.Object implements JavaMailSender
JavaMailSender interface,
 supporting both JavaMail MimeMessages and Spring
 SimpleMailMessages. Can also be used as a
 plain MailSender implementation.
 Allows for defining all settings locally as bean properties.
 Alternatively, a pre-configured JavaMail Session can be
 specified, possibly pulled from an application server's JNDI environment.
 
Non-default properties in this object will always override the settings
 in the JavaMail Session. Note that if overriding all values locally,
 there is no added value in setting a pre-configured Session.
MimeMessage, 
Session, 
setSession(javax.mail.Session), 
setJavaMailProperties(java.util.Properties), 
setHost(java.lang.String), 
setPort(int), 
setUsername(java.lang.String), 
setPassword(java.lang.String)| Modifier and Type | Field and Description | 
|---|---|
| static int | DEFAULT_PORTThe default port: -1 | 
| static java.lang.String | DEFAULT_PROTOCOLThe default protocol: 'smtp' | 
| Constructor and Description | 
|---|
| JavaMailSenderImpl()Create a new instance of the  JavaMailSenderImplclass. | 
| Modifier and Type | Method and Description | 
|---|---|
| protected Transport | connectTransport()Obtain and connect a Transport from the underlying JavaMail Session,
 passing in the specified host, port, username, and password. | 
| MimeMessage | createMimeMessage()This implementation creates a SmartMimeMessage, holding the specified
 default encoding and default FileTypeMap. | 
| MimeMessage | createMimeMessage(java.io.InputStream contentStream)Create a new JavaMail MimeMessage for the underlying JavaMail Session
 of this sender, using the given input stream as the message source. | 
| protected void | doSend(MimeMessage[] mimeMessages,
      java.lang.Object[] originalMessages)Actually send the given array of MimeMessages via JavaMail. | 
| java.lang.String | getDefaultEncoding()Return the default encoding for  MimeMessages,
 ornullif none. | 
| FileTypeMap | getDefaultFileTypeMap() | 
| java.lang.String | getHost()Return the mail server host. | 
| java.util.Properties | getJavaMailProperties()Allow Map access to the JavaMail properties of this sender,
 with the option to add or override specific entries. | 
| java.lang.String | getPassword()Return the password for the account at the mail host. | 
| int | getPort()Return the mail server port. | 
| java.lang.String | getProtocol()Return the mail protocol. | 
| Session | getSession()Return the JavaMail  Session,
 lazily initializing it if hasn't been specified explicitly. | 
| protected Transport | getTransport(Session session)Obtain a Transport object from the given JavaMail Session,
 using the configured protocol. | 
| java.lang.String | getUsername()Return the username for the account at the mail host. | 
| void | send(MimeMessage... mimeMessages)Send the given array of JavaMail MIME messages in batch. | 
| void | send(MimeMessage mimeMessage)Send the given JavaMail MIME message. | 
| void | send(MimeMessagePreparator... mimeMessagePreparators)Send the JavaMail MIME messages prepared by the given MimeMessagePreparators. | 
| void | send(MimeMessagePreparator mimeMessagePreparator)Send the JavaMail MIME message prepared by the given MimeMessagePreparator. | 
| void | send(SimpleMailMessage... simpleMessages)Send the given array of simple mail messages in batch. | 
| void | send(SimpleMailMessage simpleMessage)Send the given simple mail message. | 
| void | setDefaultEncoding(java.lang.String defaultEncoding)Set the default encoding to use for  MimeMessagescreated by this instance. | 
| void | setDefaultFileTypeMap(FileTypeMap defaultFileTypeMap)Set the default Java Activation  FileTypeMapto use forMimeMessagescreated by this instance. | 
| void | setHost(java.lang.String host)Set the mail server host, typically an SMTP host. | 
| void | setJavaMailProperties(java.util.Properties javaMailProperties)Set JavaMail properties for the  Session. | 
| void | setPassword(java.lang.String password)Set the password for the account at the mail host, if any. | 
| void | setPort(int port)Set the mail server port. | 
| void | setProtocol(java.lang.String protocol)Set the mail protocol. | 
| void | setSession(Session session)Set the JavaMail  Session, possibly pulled from JNDI. | 
| void | setUsername(java.lang.String username)Set the username for the account at the mail host, if any. | 
| void | testConnection()Validate that this instance can connect to the server that it is configured
 for. | 
public static final java.lang.String DEFAULT_PROTOCOL
public static final int DEFAULT_PORT
public JavaMailSenderImpl()
JavaMailSenderImpl class.
 Initializes the "defaultFileTypeMap"
 property with a default ConfigurableMimeFileTypeMap.
public void setJavaMailProperties(java.util.Properties javaMailProperties)
Session.
 A new Session will be created with those properties.
 Use either this method or setSession(javax.mail.Session), but not both.
 
Non-default properties in this instance will override given JavaMail properties.
public java.util.Properties getJavaMailProperties()
Useful for specifying entries directly, for example via "javaMailProperties[mail.smtp.auth]".
public void setSession(Session session)
Session, possibly pulled from JNDI.
 Default is a new Session without defaults, that is
 completely configured via this instance's properties.
 
If using a pre-configured Session, non-default properties
 in this instance will override the settings in the Session.
public Session getSession()
Session,
 lazily initializing it if hasn't been specified explicitly.public void setProtocol(java.lang.String protocol)
public java.lang.String getProtocol()
public void setHost(java.lang.String host)
Default is the default host of the underlying JavaMail Session.
public java.lang.String getHost()
public void setPort(int port)
Default is DEFAULT_PORT, letting JavaMail use the default
 SMTP port (25).
public int getPort()
public void setUsername(java.lang.String username)
Note that the underlying JavaMail Session has to be
 configured with the property "mail.smtp.auth" set to
 true, else the specified username will not be sent to the
 mail server by the JavaMail runtime. If you are not explicitly passing
 in a Session to use, simply specify this setting via
 setJavaMailProperties(java.util.Properties).
public java.lang.String getUsername()
public void setPassword(java.lang.String password)
Note that the underlying JavaMail Session has to be
 configured with the property "mail.smtp.auth" set to
 true, else the specified password will not be sent to the
 mail server by the JavaMail runtime. If you are not explicitly passing
 in a Session to use, simply specify this setting via
 setJavaMailProperties(java.util.Properties).
public java.lang.String getPassword()
public void setDefaultEncoding(java.lang.String defaultEncoding)
MimeMessages
 created by this instance.
 Such an encoding will be auto-detected by MimeMessageHelper.
public java.lang.String getDefaultEncoding()
MimeMessages,
 or null if none.public void setDefaultFileTypeMap(FileTypeMap defaultFileTypeMap)
FileTypeMap to use for
 MimeMessages created by this instance.
 A FileTypeMap specified here will be autodetected by
 MimeMessageHelper, avoiding the need to specify the
 FileTypeMap for each MimeMessageHelper instance.
 
For example, you can specify a custom instance of Spring's
 ConfigurableMimeFileTypeMap here. If not explicitly specified,
 a default ConfigurableMimeFileTypeMap will be used, containing
 an extended set of MIME type mappings (as defined by the
 mime.types file contained in the Spring jar).
public FileTypeMap getDefaultFileTypeMap()
public void send(SimpleMailMessage simpleMessage) throws MailException
MailSendersend in interface MailSendersimpleMessage - the message to sendMailParseException - in case of failure when parsing the messageMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending the messageMailExceptionpublic void send(SimpleMailMessage... simpleMessages) throws MailException
MailSendersend in interface MailSendersimpleMessages - the messages to sendMailParseException - in case of failure when parsing a messageMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending a messageMailExceptionpublic MimeMessage createMimeMessage()
MimeMessageHelper, which will use
 the carried encoding and FileTypeMap unless explicitly overridden.createMimeMessage in interface JavaMailSendersetDefaultEncoding(java.lang.String), 
setDefaultFileTypeMap(javax.activation.FileTypeMap)public MimeMessage createMimeMessage(java.io.InputStream contentStream) throws MailException
JavaMailSendercreateMimeMessage in interface JavaMailSendercontentStream - the raw MIME input stream for the messageMailParseException - in case of message creation failureMailExceptionpublic void send(MimeMessage mimeMessage) throws MailException
JavaMailSenderJavaMailSender.createMimeMessage().send in interface JavaMailSendermimeMessage - message to sendMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending the messageMailExceptionJavaMailSender.createMimeMessage()public void send(MimeMessage... mimeMessages) throws MailException
JavaMailSenderJavaMailSender.createMimeMessage().send in interface JavaMailSendermimeMessages - messages to sendMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending a messageMailExceptionJavaMailSender.createMimeMessage()public void send(MimeMessagePreparator mimeMessagePreparator) throws MailException
JavaMailSenderAlternative way to prepare MimeMessage instances, instead of
 JavaMailSender.createMimeMessage() and JavaMailSender.send(MimeMessage) calls.
 Takes care of proper exception conversion.
send in interface JavaMailSendermimeMessagePreparator - the preparator to useMailPreparationException - in case of failure when preparing the messageMailParseException - in case of failure when parsing the messageMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending the messageMailExceptionpublic void send(MimeMessagePreparator... mimeMessagePreparators) throws MailException
JavaMailSenderAlternative way to prepare MimeMessage instances, instead of
 JavaMailSender.createMimeMessage() and JavaMailSender.send(MimeMessage[]) calls.
 Takes care of proper exception conversion.
send in interface JavaMailSendermimeMessagePreparators - the preparator to useMailPreparationException - in case of failure when preparing a messageMailParseException - in case of failure when parsing a messageMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending a messageMailExceptionpublic void testConnection()
                    throws MessagingException
MessagingException if the connection attempt failed.MessagingExceptionprotected void doSend(MimeMessage[] mimeMessages, java.lang.Object[] originalMessages) throws MailException
mimeMessages - MimeMessage objects to sendoriginalMessages - corresponding original message objects
 that the MimeMessages have been created from (with same array
 length and indices as the "mimeMessages" array), if anyMailAuthenticationException - in case of authentication failureMailSendException - in case of failure when sending a messageMailExceptionprotected Transport connectTransport() throws MessagingException
MessagingException - if the connect attempt failedgetTransport(javax.mail.Session), 
getHost(), 
getPort(), 
getUsername(), 
getPassword()protected Transport getTransport(Session session) throws NoSuchProviderException
Can be overridden in subclasses, e.g. to return a mock Transport object.
NoSuchProviderExceptionSession.getTransport(String), 
getSession(), 
getProtocol()