WAS v8.5 > Secure applications > Secure communicationsCreate an SSL configuration
Overview
SSL configurations contain the attributes needed to control the behavior of client and server SSL endpoints. We create SSL configurations with unique names within specific management scopes on the inbound and outbound tree in the configuration topology. This task shows you how to define SSL configurations, including quality of protection and trust and key manager settings.
You must decide at which scope to define an SSL configuration, for instance, the cell, node group, node, server, cluster, or endpoint scope, from the least specific to the most specific scope. When you define an SSL configuration at the node scope, for example, only those processes within that node can load the SSL configuration; however, any processes at the endpoint in the cell can use an SSL configuration at the cell scope, which is higher in the topology.
You must also decide which scope to associate with the new SSL configuration, according to the processes the configuration affects. For example, an SSL configuration for a hardware cryptographic device might require a keystore that is available only on a specific node, or we might need an SSL configuration for a connection to a particular SSL host and port.
The security.xml file is restricted. To make changes to the security.xml file, verify the user ID has administrator role authorization. If we are using a user ID with operator role authorization, we can perform a node synchronization, but any changes made to the security.xml file are not synchronized.
Create an SSL configuration
Complete the following steps in the dmgr console:
- Click...
Security | SSL certificate and key management | Manage endpoint security configurations
- Select an SSL configuration link on either the Inbound or Outbound tree, depending on the process you are configuring.
- If the scope is already associated with a configuration and alias, the SSL configuration alias and certificate alias are noted in parentheses.
- If the parenthetical information is not included, then the scope is not associated. Instead, the scope inherits the configuration properties of the first scope above it associated with an SSL configuration and certificate alias.
The cell scope must be associated with an SSL configuration because it is at the top of the topology and represents the default SSL configuration for the inbound or outbound connection.
- Click...
Related Items | SSL configurations
We can view and select any of the SSL configurations configured at this scope. We can also view and select these configuration at every scope that is lower on the topology.
- Click New to display the SSL configuration panel.
We cannot select links under Additional Properties until you type a configuration name and click Apply.
- Type an SSL configuration name.
This field is required. The configuration name is the SSL configuration alias.
Make the alias name unique within the list of SSL configuration aliases that are already created at the selected scope. The new SSL configuration uses this alias for other configuration tasks.
- Select a truststore name from the drop-down list.
A truststore name refers to a specific truststore that holds signer certificates that validate the trust of certificates sent by remote connections during an SSL handshake. If there is no truststore in the list, see Create a keystore configuration for a preexisting keystore file to create a new truststore, which is a keystore whose role is to establish trust during the connection.
- Select a keystore name from the drop-down list.
A keystore contains the personal certificates that represent a signer identity and the private key that WAS uses to encrypt and sign data.
- If you change the keystore name, to refresh the list of certificates from which we can choose a default alias, click...
Get certificate aliases
WAS uses a server alias for inbound connections and a client alias for outbound connections.
- If there is no keystore in the list, see Create a keystore configuration for a preexisting keystore file to create a new keystore.
- Choose a default server certificate alias for inbound connections.
Select the default only when we have not specified an SSL configuration alias elsewhere and have not selected a certificate alias. A centrally managed SSL configuration tree can override the default alias.
- Choose a default client certificate alias for outbound connections.
Select the default only when the server SSL configuration specifies an SSL client authentication.
- Review the identified management scope for the SSL configuration.
Make the management scope in this field identical to the link you selected in Step 2. To change the scope, you must click a different link in the topology tree and continue at Step 3.
- Click Apply if you intend to configure Additional Properties. If not, go to Step 24.
- Click Quality of protection (QoP) settings under Additional Properties.
QoP settings define the strength of the SSL encryption, the integrity of the signer, and the authenticity of the certificate.
- Select a client authentication setting to establish an SSL configuration for inbound connections and for clients to send their certificates, if appropriate.
- If you select None, the server does not request that a client send a certificate during the handshake.
- If you select Supported, the server requests that a client send a certificate. However, if the client does not have a certificate, the handshake might still succeed.
- If you select Required, the server requests that a client send a certificate. However, if the client does not have a certificate, the handshake fails.
The signer certificate that represents the client must be in the truststore that you select for the SSL configuration.
By default, servers within the same cell trust each other because they use the common truststore, trust.p12, located in the cell directory of the configuration repository. However, if we use keystores and truststores that you create, perform a signer exchange before you select either Supported or Required.
- Select a protocol for the SSL handshake.
- SSL_TLS. Default protocol Supports client protocols TLSv1 and SSLv3.
- TLSv1. Supports TLS and TLSv1. The SSL server connection must support this protocol for the handshake to proceed.
- SSLv2
- SSLv3. Supports SSL and SSLv3. The SSL server connection must support this protocol for the handshake to proceed.
- TLS is TLSv1
- TLSv1
- SSL_TLSv2 is SSLv3 and TLSv1, TLSv1.1, TLSv1.2
- TLSv1.1
- TLSv1.2
Do not use the SSLv2 protocol for the SSL server connection. Use it only when necessary on the client side.
- Select one of the following options:
- A predefined JSSE provider. The IBMJSSE2 provider is recommended for use on all platforms which support it. It is required for use by the channel framework SSL channel. When Federal Information Processing Standard (FIPS) is enabled, IBMJSSE2 is used in combination with the IBMJCEFIPS crypto provider.
- A custom JSSE provider. Type a provider name in the Custom provider field.
- Select from among the following cipher suite groups:
- Strong: WAS can perform 128-bit confidentiality algorithms for encryption and support integrity signing algorithms. However, a strong cipher suite can affect the performance of the connection.
- Medium: WAS can perform 40-bit encryption algorithms for encryption and support integrity signing algorithms.
- Weak: WAS can support integrity signing algorithms but not to perform encryption. Select this option with care because passwords and other sensitive information that cross the network are visible to an Internet Protocol (IP) sniffer.
- Custom: we can select specific ciphers. Any time you change the ciphers listed from a specific cipher suite group, the group name changes to Custom.
- Click Update selected ciphers to view a list of the available ciphers for each cipher strength.
- Click OK to return to the new SSL configuration panel.
- Click Trust and key managers under Additional Properties.
- Select a default trust manager for the primary SSL handshake trust decision.
- Choose IbmPKIX when we require certificate revocation list (CRL) checking using CRL distribution points in the certificates or the online certificate status protocol (OCSP).
- Choose IbmX509 when we do not require CRL checking but do need increased performance. We can configure a custom trust manager to perform CRL checking, if necessary.
- Define a custom trust manager, if appropriate. We can define a custom trust manager that runs with the default trust manager you select. The custom trust manager must implement the JSSE javax.net.ssl.X509TrustManager interface and, optionally, the com.ibm.wsspi.ssl.TrustManagerExtendedInfo interface to obtain product-specific information.
- Click...
Security | SSL certificate and key management | Manage endpoint security configurations | SSL_configuration | Trust and key managers | Trust managers | New
- Type a unique trust manager name.
- Select the Custom option.
- Type a class name.
- Click OK.
When you return to the Trust and key managers panel, the new custom trust manager displays in the Additional ordered trust managers field. Use the left and right list boxes to add and remove custom trust managers.
- Select a key manager for the SSL configuration. By default, IbmX509 is the only key manager unless you create a custom key manager.
If you choose to implement our own key manager, we can affect the alias selection behavior because the key manager is responsible for selecting the certificate alias from the keystore. The custom key manager might not interpret the SSL configuration as the WAS key manager IbmX509 does. To define a custom key manager, click...
Security | Secure communications | SSL configurations | SSL_configuration | Trust and key managers | Key managers | New
- Click OK to save the trust and key manager settings and return to the new SSL configuration panel.
- Click Save to save the new SSL configuration.
Results
We can override the default trust manager when we configure at least one custom trust manager and set the com.ibm.ssl.skipDefaultTrustManagerWhenCustomDefined property to true. Click Custom Property on the SSL configuration panel. However, if you change the default, you leave all the trust decisions to the custom trust manager, which is not recommended for production environments. In test environments, use a dummy trust manager to avoid certificate validation. Remember these environment are not secure.
In this release of WAS, we can associate SSL configurations with protocols using one of the following methods:
- Set the SSL configuration on the thread programmatically
- Associate the SSL configuration with an outbound protocol, and target host and port.
- Associate the SSL configuration directly using the alias.
- Manage the SSL configurations centrally by associating them with SSL configuration groups or zones scoped for endpoints.
Subtopics
- SSL certificate and key management
- SSL configurations for selected scopes
- SSL configurations page
- SSL configuration settings
- Certificate authority (CA) client configuration
- Certificate authority (CA) client configuration collections
- Create a chained personal certificate in SSL
- Recovering deleted certificates in SSL
- Renewing a certificate in SSL
- Revoking a CA certificate in SSL
- Use a CA client to create a personal certificate to be used as the default personal certificate
- Create a CA certificate in SSL
- Develop the WSPKIClient interface for communicating with a certificate authority
- Create a custom trust manager configuration for SSL
- Create a custom key manager for SSL
- Associate an SSL configuration dynamically with an outbound protocol and remote secure endpoint
- Secure Sockets Layer client certificate authentication
- Quality of protection (QoP) settings
- ssl.client.props client configuration file
- SSL certificate and key management
- SSL configurations for selected scopes
- SSL configurations page
- SSL configuration settings
- Secure Sockets Layer client certificate authentication
- Certificate authority (CA) client configuration
- Certificate authority (CA) client configuration collections
- Create a chained personal certificate in SSL
- Recovering deleted certificates in SSL
- Renewing a certificate in SSL
- Revoking a CA certificate in SSL
- Use a CA client to create a personal certificate to be used as the default personal certificate
- Create a CA certificate in SSL
- Develop the WSPKIClient interface for communicating with a certificate authority
- Create a custom trust manager configuration for SSL
- Create a custom key manager for SSL
- Associate an SSL configuration dynamically with an outbound protocol and remote secure endpoint
- Quality of protection (QoP) settings
- ssl.client.props client configuration file
Related
Automating SSL configurations using scripting
SSLConfigCommands command group for AdminTask