{"/api/v1/ncpl/currencies/getAll":{"body":[{"Name":"U.S. Dollar","Code":"USD","Symbol":"$","Separator":".","Culture":"en-US"},{"Name":"Euro","Code":"EUR","Symbol":"€","Separator":",","Culture":"en-US"},{"Name":"British Pound","Code":"GBP","Symbol":"£","Separator":".","Culture":"en-US"},{"Name":"Canadian Dollars","Code":"CAD","Symbol":"C$","Separator":".","Culture":"en-US"},{"Name":"Australian Dollars","Code":"AUD","Symbol":"A$","Separator":".","Culture":"en-US"},{"Name":"Indian Rupees","Code":"INR","Symbol":"Rs","Separator":".","Culture":"en-US"},{"Name":"China Yuan RMB","Code":"CNY","Symbol":"¥","Separator":".","Culture":"en-US"}],"status":200,"statusText":"OK"},"/api/v1/ncpl/usermanagement/uiuser/getHeaderUserInfo:\"{\\\"hideSupportPin\\\":true}\"":{"body":{"__ctxId":"A64A2953E28C4D928A020A1F59A9D3A7","__isError":true,"__errorType":"Nc.Platform.Abstractions.UnauthorizedException","Http_WWW_Authenticate":"Bearer","StatusCode":"Unauthorized","LogLevel":3,"Message":"","InnerException":null,"HelpLink":null,"Source":"Nc.Security.Middleware"},"status":401,"statusText":"Unauthorized"},"/api/v1/ncpl/cart/user/getShoppingCartSummary:\"{\\\"finalTotalOnly\\\":true}\"":{"body":null,"status":200,"statusText":"OK"}}
{"/api/v1/ncpl/simplekb/getarticle:\"{\\\"articleId\\\":9441,\\\"categoryId\\\":33}\"":{"body":{"Id":9441,"FriendlyId":"","ArticleTypeId":0,"Title":"Installing an SSL certificate on Tomcat","ArticleName":"Installing an SSL certificate on Tomcat","ArticleSummary":null,"PreponedSummary":false,"Approved":true,"Body":"
		<div>This guide is intended for those with Apache Tomcat <a href="https://tomcat.apache.org/tomcat-9.0-doc/setup.html" linktext="set up" linktype="Custom" target="_blank">set up</a> with your website running on either default port 8080 or 80 via the HTTP protocol. Once this condition is met, SSL installation can be initiated.</div>
		<div>
				<br />
		</div>
		<div>Tomcat provides you with quite a flexible way of installing SSL, unlike most other servers. SSL certificates can be installed through either APR (Apache Portable Runtime) or JSSE (Java Secure Socket Extension) connectors. The JSSE method is the most widely used connector that includes interaction with Java keystores created via <code><b>keytool</b></code>. APR simplifies SSL installation to the usual Apache-like process.</div>
		<div>
				<br />
		</div>
		<ul>
				<li>
						<a href="#1">Prerequisites</a>
				</li>
				<li>
						<a href="#2">Java keystores</a>
						<ul>
								<li>
										<a href="#2_1">PKCS7</a>
								</li>
								<li>
										<a href="#2_2">PEM</a>
								</li>
								<li>
										<a href="#2_3">PKCS12</a>
								</li>
						</ul>
				</li>
				<li>
						<a href="#3">APR-based installation</a>
				</li>
				<li>
						<a href="#4">Apply the changes</a>
				</li>
				<li>
						<a href="#5">Troubleshooting</a>
						<ul>
								<li>
										<a href="#5_1">View keystore content</a>
								</li>
								<li>
										<a href="#5_2">Extract Private key from keystore</a>
								</li>
								<li>
										<a href="#5_3">Proprietary keystore format warning</a>
								</li>
						</ul>
				</li>
		</ul>
		<h2 id="1">Prerequisites</h2>
		<div>Make sure that you have <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/10095/67/how-to-enable-an-ssl-certificate" linktext="issued and active SSL certificate" linktype="Custom" target="_blank">issued and active SSL certificate</a> files prepared prior to proceeding with SSL installation. You can <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9464/69/can-i-download-an-issued-certificate-on-your-site" linktext="download the active certificate" linktype="Custom" target="_blank">download the active certificate</a> from your account directly.<br /><br />If the CSR was generated using the keytool on your server, you can stick to the <a href="#2_1">PKCS7</a> installation steps. If you generated the CSR elsewhere and have the matching Private key, use the <a href="#2_3">PKCS12</a> or <a href="#3">APR-based installation</a>.<br /><br /><b>Important</b>: If you have <i>separate Private key</i> and certificate files, you will need to <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9617/69/how-to-convert-certificates-into-different-formats-using-openssl" linktext="convert" linktype="Custom" target="_blank">convert</a> them into a PKCS#12 file first, unless there is an <a href="#3">APR configured along with your Tomcat</a>. Once the files are converted, you can proceed with the respective <a href="#2_3">PKCS#12 installation steps</a>.</div>
		<div>
				<br />
		</div>
		<h2 id="2">Java keystores</h2>
		<div>After you have <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9422/14/generating-a-csr-on-tomcat-using-a-keytool" linktext="created a keystore" linktype="Custom" target="_blank">created a keystore</a> containing the Private key along with the corresponding CSR, you will need to import your issued SSL certificate into the keystore under the main keystore alias. Each time you interact with a keystore file, you will need to enter its password. Below is an overview of all the possible ways of adding a certificate to your keystore.</div>
		<div>
				<br />
		</div>
		<h3 id="2_1">PKCS#7</h3>
		<div>The most time-efficient way to install your SSL on Tomcat from a keystore is to use a PKCS#7 formatted certificate (a file with the .p7b or .cer extension).</div>
		<div>
				<br />
		</div>
		<h4>Step 1: Upload SSL files</h4>
		<p>Upload the PKCS#7 certificate file on the server. Then, import it using the following command:</p>
		<p>
				<code>
						<b>keytool -import -trustcacerts -alias tomcat -file certificate.p7b -keystore yourkeystore.jks</b>
				</code>
		</p>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>tomcat</b>
						</code> is the actual alias of your keystore</li>
				<li>
						<code>
								<b>certificate.p7b</b>
						</code> is the actual name/path to your certificate file</li>
				<li>
						<code>
								<b>yourkeystore.jks</b>
						</code> is the actual name/path to the keystore file</li>
		</ul>
		<p>Make sure the certificate file has the same alias used for <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9422/14/generating-a-csr-on-tomcat-using-a-keytool" linktext="creating the keystore" linktype="Custom" target="_blank">creating the keystore</a>. Otherwise, the “<a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9784/2238/tomcat-installation-error-input-not-an-x509-certificate" linktext="Input not an X.509 certificate" linktype="Custom" target="_blank">Input not an X.509 certificate</a>” error may take place.</p>
		<p>After you have imported successfully, you should receive the following output:</p>
		<p>
				<code>
						<b>Certificate reply was installed in keystore</b>
				</code>
		</p>
		<h4>Step 2: Edit SSL Configuration</h4>
		<p>In the next step, you will need to modify the connector for the default port 8443 or 443.</p>
		<p>The modification should be done in the <code><b>‘Tomcat installation directory’/conf/server.xml</b></code> file. You can find the location of the directory containing the <code><b>server.xml</b></code> configuration file by issuing this command:</p>
		<p>
				<code>
						<b>sudo find / -ipath '*tomcat*server.xml'</b>
				</code>
		</p>
		<p>It will most likely be in <code><b>/opt/tomcat/conf/server.xml</b></code> or <code><b>/etc/tomcat/server.xml</b></code></p>
		<p>Here is an example of a JSSE connector for port 443 using the HTTP/1.1 protocol with TLS up to 1.3 enabled:</p>
		<div>
				<code>
						<b>&lt;Connector</b>
				</code>
		</div>
		<div>
				<code>
						<b>protocol="org.apache.coyote.http11.Http11NioProtocol"</b>
				</code>
		</div>
		<div>
				<code>
						<b>port="443"</b>
				</code>
		</div>
		<div>
				<code>
						<b>maxThreads="200"</b>
				</code>
		</div>
		<div>
				<code>
						<b>scheme="https"</b>
				</code>
		</div>
		<div>
				<code>
						<b>secure="true"</b>
				</code>
		</div>
		<div>
				<code>
						<b>SSLEnabled="true"</b>
				</code>
		</div>
		<div>
				<code>
						<b>keystoreFile="/opt/tomcat/ssl/yourkeystore.jks"</b>
				</code>
		</div>
		<div>
				<code>
						<b>keystorePass="keystore_password"</b>
				</code>
		</div>
		<div>
				<code>
						<b>clientAuth="false"</b>
				</code>
		</div>
		<div>
				<code>
						<b>sslProtocol="TLS"/&gt;</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>/opt/tomcat/ssl/yourkeystore.jks</b>
						</code> is the absolute path and actual name of the keystore file</li>
				<li>
						<code>
								<b>keystore_password</b>
						</code> is the actual password for your keystore</li>
		</ul>
		<h4>Step 3: Apply changes</h4>
		<p>Once done, please restart Tomcat in order to apply the changes. If you are not quite sure about the steps to reproduce, feel free to jump to <a href="#4">this section</a> to apply the changes and verify SSL installation.</p>
		<p>
				<br />
		</p>
		<h3 id="2_2">PEM</h3>
		<p>The most challenging, yet still common, way of installing an SSL certificate on Tomcat is by using separate PEM-formatted SSL certificates.</p>
		<h4>Step 1: Prepare the files</h4>
		<p>This method requires you to have each of the certificates saved in separate files:</p>
		<ol>
				<li>CA root certificate.</li>
				<li>CA second intermediate certificate (optional and can be omitted if your CA bundle contains only 1 intermediate certificate).</li>
				<li>CA intermediate certificate.</li>
				<li>End-entity certificate for your domain.</li>
		</ol>
		<p>The order of the certificate will be as follows for the most frequently used <a href="https://www.namecheap.com/security/ssl-certificates/comodo/positivessl/" linktext="PositiveSSL" linktype="Custom" target="_blank">PositiveSSL</a> certificate:</p>
		<div>
				<code>
						<b>keytool -import AAA Certificate Services</b>
				</code>
		</div>
		<div>
				<code>
						<b>keytool -import USERTrust RSA Certification Authority</b>
				</code>
		</div>
		<div>
				<code>
						<b>keytool -import Sectigo RSA Domain Validation Secure Server CA</b>
				</code>
		</div>
		<div>
				<code>
						<b>keytool -import example.com.crt</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<p>
				<i>
						<b>Note:</b> You can find more CA Bundles <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9393/69/where-do-i-find-ssl-ca-bundle/" linktext="here" linktype="Custom" target="_blank">here</a>.</i>
		</p>
		<p>
				<i>
						<b>Note:</b> The “AAA Certificate Services” is only installed if you chose the CA Bundle containing the cross-signed certificate.</i>
		</p>
		<p>The above list is composed in reverse order on purpose as this is the exact order in which the certificates should be imported to the keystore. You can <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9464/69/can-i-download-an-issued-certificate-on-your-site" linktext="download the certificate files" linktype="Custom" target="_blank">download the certificate files</a> from your Namecheap account along with the CA bundle. Here is the <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9393/69/where-do-i-find-ssl-ca-bundle" linktext="dedicated page" linktype="Custom" target="_blank">dedicated page</a> with download links if you only need the CA bundle. It may come in handy if you encounter the “<a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9780/2238/tomcat-installation-error-keytool-error-javalangexception-failed-to-establish-chain-from-reply" linktext="keytool error: java.langException: Failed to establish chain from reply" linktype="Custom" target="_blank">keytool error: java.langException: Failed to establish chain from reply</a>” error.</p>
		<h4>Step 2: Import the files</h4>
		<p>Follow the below steps in the given order to import the files properly.</p>
		<p>Import the root certificate by running:</p>
		<p>
				<code>
						<b>keytool -import -trustcacerts -alias root -file root.crt -keystore yourkeystore.jks</b>
				</code>
		</p>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>root</b>
						</code> is the alias of the imported CA root certificate</li>
				<li>
						<code>
								<b>root.crt</b>
						</code> is the actual name/path of your CA root certificate</li>
				<li>
						<code>
								<b>yourkeystore.jks</b>
						</code> is the actual name/path of the keystore file</li>
		</ul>
		<p>
				<i>
						<b>Note:</b> During import of the CA root certificate, you may be prompted with the following message.</i>
		</p>
		<p>
				<code>
						<b>Certificate already exists in system-wide CA keystore under alias &lt;aliasname&gt;<br />Do you still want to add it to your own keystore? [no]:</b>
				</code>
		</p>
		<p>
				<i>Disregard the warning and confirm certificate import with submitting <code><b>y</b></code></i>.</p>
		<p>Import the second intermediate certificate:</p>
		<p>
				<code>
						<b>keytool -import -trustcacerts -alias intermediate2 -file intermediate_2.crt -keystore yourkeystore.jks</b>
				</code>
		</p>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>intermediate2</b>
						</code> is the alias of the imported second intermediate CA certificate</li>
				<li>
						<code>
								<b>intermediate_2.crt</b>
						</code> is the actual name/path of your second intermediate CA certificate</li>
		</ul>
		<p>Import the first intermediate certificate:</p>
		<p>
				<code>
						<b>keytool -import -trustcacerts -alias intermediate1 -file intermediate_1.crt -keystore yourkeystore.jks</b>
				</code>
		</p>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>intermediate1</b>
						</code> is the alias of the imported first intermediate CA certificate</li>
				<li>
						<code>
								<b>intermediate_1.crt</b>
						</code> is the actual actual name/path of your first intermediate CA certificate</li>
		</ul>
		<p>After the successful import of each of the above certificates, you should receive the following output:</p>
		<p>
				<code>
						<b>Certificate was added to keystore</b>
				</code>
		</p>
		<p>Import the end-entity certificate for your domain:</p>
		<p>
				<code>
						<b>keytool -import -trustcacerts -alias tomcat -file certificate.crt -keystore yourkeystore.jks</b>
				</code>
		</p>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>tomcat</b>
						</code> is the actual alias of your keystore. The alias for your end-entity certificate should be the same as the one you used when creating the keystore with the Private key. If you did not specify the alias during the keystore creation, the default value will be <b>mykey</b>.</li>
				<li>
						<code>
								<b>certificate.crt</b>
						</code> is the actual actual name/path of your end-entity certificate file.</li>
		</ul>
		<p>After import of the end-entity certificate, the below message will be prompted:</p>
		<p>
				<code>
						<b>Certificate reply was installed in keystore</b>
				</code>
		</p>
		<h4>Step 3: Edit the connector</h4>
		<p>In the next step, you will need to modify the connector for the default port 8443 or 443.</p>
		<p>The modification should be done in the <code><b>‘Tomcat installation directory’/conf/server.xml</b></code> file. You can find the location of the directory containing the <code><b>server.xml</b></code> configuration file by issuing the below command:</p>
		<p>
				<code>
						<b>sudo find / -ipath '*tomcat*server.xml'</b>
				</code>
		</p>
		<p>Most likely, it will be in <code><b>/opt/tomcat/conf/server.xml</b></code> or <code><b>/etc/tomcat/server.xml</b></code></p>
		<p>Here is an example of the JSSE connector for port 443 using HTTP/1.1 protocol along with TLS up to 1.3 protocol versions:</p>
		<div>
				<code>
						<b>&lt;Connector</b>
				</code>
		</div>
		<code>
				<b>
						<div>protocol="org.apache.coyote.http11.Http11NioProtocol"</div>
						<div>port="443"</div>
						<div>maxThreads="200"</div>
						<div>scheme="https"</div>
						<div>secure="true"</div>
						<div>SSLEnabled="true"</div>
						<div>keystoreFile="/opt/tomcat/ssl/yourkeystore.jks"</div>
						<div>keystorePass="keystore_password"</div>
						<div>clientAuth="false"</div>
				</b>
		</code>
		<div>
				<code>
						<b>sslProtocol="TLS"/&gt;</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>/opt/tomcat/ssl/yourkeystore.jks</b>
						</code> is the absolute path and actual name of the keystore file</li>
				<li>
						<code>
								<b>keystore_password</b>
						</code> is the actual password for your keystore</li>
		</ul>
		<h4>Step 4: Enforce the changes</h4>
		<p>Once done, please restart Tomcat in order to apply changes.If you are not quite sure about the steps to reproduce, you can go to <a href="#4">this section</a> to apply the changes and verify SSL installation.</p>
		<p>
				<br />
		</p>
		<h3 id="2_3">PKCS#12</h3>
		<p>If you have no APR enabled on Apache Tomcat, this method of SSL installation is the optimal balance between the PKCS#7 and PEM import methods. PKCS#12 is a certificate standard when all the required parts (end-entity certificate for the hostname, CA bundle, and the Private key) are stored in the same file.</p>
		<h4>Step 1: Prepare the SSL files</h4>
		<p>Feel free to jump right to the next part if you already have a PKCS#12 (.pfx/.p12) certificate. If you do not have one, <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9617/69/how-to-convert-certificates-into-different-formats-using-openssl" linktext="convert the corresponding files first" linktype="Custom" target="_blank">convert the corresponding files first</a>.</p>
		<h4>Step 2: Modify the keystore</h4>
		<p>PKCS#12 file is considered as a keystore in itself. Thus, you will just need to specify the path to the PKCS#12 file in the keystoreFile directive. The process is pretty much the same as for the <a href="#2_1">PKCS7</a> and <a href="#2_2">PEM</a> standards.</p>
		<p>The modification should be done in the <code><b>‘Tomcat installation directory’/conf/server.xml</b></code> file. You can find the location of the directory containing the <code><b>server.xml</b></code> configuration file  by issuing the below command:</p>
		<p>
				<code>
						<b>sudo find / -ipath '*tomcat*server.xml'</b>
				</code>
		</p>
		<p>It will most likely be in <code><b>/opt/tomcat/conf/server.xml</b></code> or <code><b>/etc/tomcat/server.xml</b></code>.
</p>
		<p>Here is an example of PKCS#12 JSSE connector for port 443 using HTTP/1.1 protocol along with TLS up to 1.3 protocol versions:</p>
		<br />
		<code>
				<b>
						<div>&lt;Connector</div>
						<div>protocol="org.apache.coyote.http11.Http11NioProtocol"</div>
						<div>port="443"</div>
						<div>maxThreads="200"</div>
						<div>scheme="https"</div>
						<div>secure="true"</div>
						<div>SSLEnabled="true"</div>
						<div>keystoreFile="/opt/tomcat/ssl/somefile.pfx"</div>
						<div>keystorePass="password_from_your_pfx"</div>
						<div>keystoreType="PKCS12"<br /></div>
						<div>clientAuth="false"</div>
						<div>sslProtocol="TLS"/&gt;</div>
				</b>
		</code>
		<br />
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>/opt/tomcat/ssl/somefile.pfx</b>
						</code> is the absolute path and actual name for the PKCS#12 certificate</li>
				<li>
						<code>
								<b>password_from_your_pfx</b>
						</code> is the actual password for the PKCS#12 file</li>
		</ul>
		<i>
				<b>Note</b>: In all cases when you use PKCS12 file, the <code><b>"keystoreType"</b></code> directive should be specified in the SSL configuration to define that the keystore format is PKCS#12 for the server to read the file properly.</i>
		<br />
		<ul>
		</ul>
		<h4>Step 3: Complete the SSL installation</h4>
		<p>Once done, please restart Tomcat in order to apply changes. If you are not quite sure about the steps to reproduce, skip to this section to apply the changes and verify SSL installation.</p>
		<p>
				<br />
		</p>
		<h2 id="3">APR-based installation</h2>
		<p>Most Linux distributions ship packages for APR out-of-the-box. Still, additional <code><b>libtcnative</b></code>, <code><b>libapr1-dev</b></code> and <code><b>libssl-dev</b></code> packages are required for APR to function properly with Tomcat (if you do not have installed them yet). Tomcat Native libraries also need to be compiled. We do not address this topic in this guide; it’s assumed you already have APR <a href="https://tomcat.apache.org/tomcat-9.0-doc/setup.html" linktext="set up" linktype="Custom" target="_blank">set up</a> with Tomcat. If no APR is set up on your Apache Tomcat, check out this <a href="#1">installation method</a>.</p>
		<h4>Step 1: Upload files</h4>
		<p>First, upload the certificate, the Private key, and the CA bundle (if the Certificate Signing Request was generated elsewhere) to the server.</p>
		<h4>Step 2: Configure the connector</h4>
		<p>Next, modify the existing connector for the default port 8443 or 443. The modification should be done in the <code><b>‘Tomcat installation directory’/conf/server.xml file</b></code>.</p>
		<p>You can find the location of the directory containing the server.xml configuration file by issuing below command:</p>
		<p>
				<code>
						<b>sudo find / -ipath '*tomcat*server.xml'</b>
				</code>
		</p>
		<p>It will most likely be in <code><b>/opt/tomcat/conf/server.xml</b></code> or <code><b>/etc/tomcat/server.xml</b></code></p>
		<p>Here is an example of the APR connector for the port 443 using HTTP/1.1 protocol along with TLS1.1 &amp; TLS1.2 enabled:</p>
		<div>
				<code>
						<b>&lt;Connector</b>
				</code>
		</div>
		<code>
				<b>
						<div>protocol="org.apache.coyote.http11.Http11AprProtocol"</div>
						<div>port="443"</div>
						<div>maxThreads="200"</div>
						<div>scheme="https"</div>
						<div>secure="true"</div>
						<div>SSLEnabled="true"</div>
						<div>SSLCertificateFile="/opt/tomcat/ssl/cert.crt"</div>
						<div>SSLCertificateChainFile="/opt/tomcat/ssl/bundle.ca-bundle"</div>
						<div>SSLCertificateKeyFile="/opt/tomcat/ssl/private.key"</div>
				</b>
		</code>
		<div>
				<code>
						<b>SSLVerifyClient="optional"</b>
				</code>
		</div>
		<div>
				<code>
						<b>SSLProtocol="TLSv1.1+TLSv1.2"/&gt;</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>/opt/tomcat/ssl/cert.crt</b>
						</code> is the absolute path and actual name of the PEM-formatted certificate</li>
				<li>
						<code>
								<b>/opt/tomcat/ssl/bundle.ca-bundle</b>
						</code> is the absolute path and actual name of the CA bundle file</li>
				<li>
						<code>
								<b>/opt/tomcat/ssl/private.key</b>
						</code> is the absolute path and actual name of the Private key file</li>
		</ul>
		<p>
				<i>
						<b>Important Note</b>: The APR connector requires you to set the SSLCertificateChainFile directive explicitly. It isn’t possible to install the certificate properly with a single file containing both the end-entity certificate and CA bundle chain, like it is usually done on Apache 2.4.8 and above. If only the SSLCertificateFile is set in the connector, the first certificate from the file will be retrieved during handshake, which could possibly trigger the ERR_CERT_AUTHORITY_INVALID error.</i>
		</p>
		<style><![CDATA[
table {
  font-family: arial, sans-serif;
  border-collapse: collapse;
  width: 100%;
}

td, th {
  border: 1px solid #dddddd;
  text-align: left;
  padding: 8px;
}

tr:nth-child(even) {
  background-color: #dddddd;
}
]]></style>
		<table>
				<tbody>
						<tr>
								<td bgcolor="#f3f3f3">
										<b>Important: Access permissions settings</b>
										<p>When installing a certificate for the APR connector, you may encounter the following error message:</p>
										<p>
												<code>
														<b>WARNING [main] org.apache.tomcat.util.net.openssl.OpenSSLContext.init Error initializing SSL context
java.lang.Exception: Unable to load certificate key /opt/tomcat/ssl/private.key (error:0200100D:system library:fopen:Permission denied)</b>
												</code>
										</p>
										<p>It is caused by improper access permissions set for the certificate and Private key files. You need to make your tomcat user the owner of the certificate and Private key files. Use the following commands to accomplish this:</p>
										<p>
												<code>
														<b>sudo chown tomcat /etc/ssl/private.key /etc/ssl/cert.crt</b>
												</code>
										</p>
										<p>Where <code><b>/opt/tomcat/ssl</b></code> is the directory containing the respective certificate and Private key files, and <code><b>tomcat</b></code> is your tomcat user.</p>
										<p>
												<b>Be aware that Tomcat is permission-sensitive, thus it will not be possible to use certificate &amp; Private key or keystore files saved in the /root or similar access-restricted directories.</b>
										</p>
								</td>
						</tr>
				</tbody>
		</table>
		<h4>
				<br />
		</h4>
		<h4>Step 3: Apply the changes</h4>
		<p>Once done, please restart Tomcat in order to apply changes. If you are not quite sure about the steps to reproduce, feel free to jump to <a href="#4">this section</a> to apply the changes and verify SSL installation.</p>
		<p>
				<br />
		</p>
		<h2 id="4">Apply the changes</h2>
		<p>Save the changes and restart Tomcat either via the systemd service if there is any available, like so:</p>
		<p>
				<code>
						<b>sudo systemctl restart tomcat</b>
				</code>
		</p>
		<p>Or by using binaries. These will most likely be found in the following location:</p>
		<div>
				<code>
						<b>/opt/tomcat/bin/shutdown.sh</b>
				</code>
		</div>
		<div>
				<code>
						<b>/opt/tomcat/bin/startup.sh</b>
				</code>
		</div>
		<p>However, the location of Tomcat binaries may vary between installations. You can find the location of both the startup and shutdown binary files by executing the below command:</p>
		<p>
				<code>
						<b>sudo find / -ipath '*tomcat*\/s[h t]*.sh'</b>
				</code>
		</p>
		<p>You will have 2 files in the output. They should be used for restarting Tomcat. Run the below commands in the following order to restart the server:</p>
		<div>
				<code>
						<b>sudo sh /opt/tomcat/bin/shutdown.sh</b>
				</code>
		</div>
		<div>
				<code>
						<b>sudo sh /opt/tomcat/bin/startup.sh</b>
				</code>
		</div>
		<p>Where:</p>
		<ul>
				<li>
						<code>
								<b>/opt/tomcat/bin/shutdown.sh</b>
						</code> is the absolute path to the <code><b>shutdown.sh</b></code> file from the previous output</li>
				<li>
						<code>
								<b>/opt/tomcat/bin/startup.sh</b>
						</code> is the absolute path to the <code><b>startup.sh</b></code> file from the previous output</li>
		</ul>
		<p>Once restarted, feel free to check the SSL installation using <a href="https://decoder.link/" linktext="this online tool" linktype="Custom" target="_blank">this online tool</a>.</p>
		<p>
				<br />
		</p>
		<h2 id="5">Troubleshooting</h2>
		<h3 id="5_1">View keystore content</h3>
		<p>Use this command to check the imported decoded certificates in the keystore. For each correctly-imported certificate, you will see its details in a keystore entry. The Private key entry is displayed in the list as well:</p>
		<p>
				<code>
						<b>keytool -list -keystore yourkeystore.jks -v</b>
				</code>
		</p>
		<p>The output should be similar to the below listing:</p>
		<div>
				<code>
						<b>$ keytool -list -keystore yourkeystore.jks -v</b>
				</code>
		</div>
		<code>
				<b>
						<div>Enter keystore password:</div>
						<div>Keystore type: PKCS12</div>
						<div>Keystore provider: SUN</div>
						<br />
						<br />
						<div>Your keystore contains 4 entries</div>
						<br />
						<br />
						<div>…</div>
						<br />
						<br />
						<div>Alias name: tomcat</div>
						<div>Creation date: Mar 13, 2020</div>
						<div>Entry type: PrivateKeyEntry</div>
						<div>Certificate chain length: 4</div>
						<div>Certificate[1]:</div>
						<div>Owner: CN=example.com</div>
						<div>Issuer: CN=Sectigo RSA Domain Validation Secure Server CA, O=Sectigo Limited, L=Salford, ST=Greater Manchester, C=GB</div>
						<div>Serial number: 45&lt;...&gt;76</div>
						<div>Valid from: Fri Mar 13 00:00:00 UTC 2020 until: Tue Mar 09 23:59:59 UTC 2021</div>
						<div>Certificate fingerprints:</div>
						<div>SHA1: 4A:BA&lt;...&gt;67:BE</div>
						<div>SHA256: D8:9D&lt;...&gt;3D:D3</div>
						<div>Signature algorithm name: SHA256withRSA</div>
						<div>Subject Public Key Algorithm: 2048-bit RSA key</div>
				</b>
		</code>
		<div>
				<code>
						<b>Version: 3</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<p>To view the keystore content with respective encoded certificates in plain text (RFC-style), use the below command:</p>
		<p>
				<code>
						<b>keytool -list -rfc -keystore yourkeystore.jks</b>
				</code>
		</p>
		<p>The output should be similar to the below listing:</p>
		<div>
				<code>
						<b>$ keytool -list -rfc -keystore yourkeystore.jks</b>
				</code>
		</div>
		<code>
				<b>
						<div>Enter keystore password:</div>
						<div>Keystore type: PKCS12</div>
						<div>Keystore provider: SUN</div>
						<br />
						<br />
						<div>Your keystore contains 4 entries</div>
						<br />
						<br />
						<div>…</div>
						<br />
						<br />
						<div>Alias name: tomcat</div>
						<div>Creation date: Mar 13, 2020</div>
						<div>Entry type: PrivateKeyEntry</div>
						<div>Certificate chain length: 4</div>
						<div>Certificate[1]:</div>
						<div>-----BEGIN CERTIFICATE-----</div>
						<div>MIIFvTCCBKWgAwIBAgIQRQgwqjjPDLDCtR8R7NN1djANBgkqhkiG9w0BAQsFADCB</div>
						<div>...</div>
						<div>6NB/mQXfhuiyeBSe4jTmr4nja6JXvjQU1GUOgrv08KuU</div>
				</b>
		</code>
		<div>
				<code>
						<b>-----END CERTIFICATE-----</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<div>
				<code>
						<b>
								<br />
						</b>
				</code>
		</div>
		<h3 id="5_2">Extract Private key from keystore</h3>
		<p>It is not possible to extract the Private key from a keystore directly, but there is a workaround with OpenSSL. You will need to:</p>
		<ol>
				<li>Convert the Java keystore file into the PKCS#12 standard file;</li>
				<li>Get the PKCS#12 file converted into a separate PEM encoded Private key file, i.e. export the Private key;</li>
				<li>View the content of the newly created Private key file.</li>
		</ol>
		<p>Follow the below commands to start the process:</p>
		<ol>
				<li>
						<code>
								<b>keytool -importkeystore -srckeystore yourkeystore.jks -destkeystore somefile.pfx -srcstoretype JKS -deststoretype PKCS12 -deststorepass password_from_your_pfx<br /></b>
						</code>
				</li>
				<style><![CDATA[
table {
  font-family: arial, sans-serif;
  border-collapse: collapse;
  width: 100%;
}

td, th {
  border: 1px solid #dddddd;
  text-align: left;
  padding: 8px;
}

tr:nth-child(even) {
  background-color: #dddddd;
}
]]></style>
				<table>
						<tbody>
								<tr>
										<td bgcolor="#f3f3f3">
												<i>
														<b>Note</b>:<br /><br />
Some Java versions running Tomcat (or another servlet container using keytool as a Private/Public keys management shell) have different prefered file extensions for PKCS#12 (e.g. older versions like JDK 1.6 and earlier can generate .p12 files). The current stable versions usually generate .pfx files. The file content of .p12 and .pfx files are essentially the same.</i>
										</td>
								</tr>
						</tbody>
				</table>
				<li>
						<code>
								<b>openssl pkcs12 -in somefile.pfx -out private.key -nocerts -nodes</b>
						</code>
				</li>
				<li>
						<code>
								<b>cat private.key</b>
						</code>
				</li>
		</ol>
		<p>Be aware that the exported Private key may contain additional attributes (such as Bag Attributes or Key Attributes) along with the key code itself. In the output file, feel free to remove the first ~4 lines standing before the <code><b>-----BEGIN PRIVATE KEY-----</b></code> tag.</p>
		<p>
				<br />
		</p>
		<h3 id="5_3">Proprietary keystore format warning</h3>
		<p>If you have a JDK version older than version 9 installed, the <a href="https://www.namecheap.com/support/knowledgebase/article.aspx/9422/14/generating-a-csr-on-tomcat-using-a-keytool" linktext="keystore will be generated" linktype="Custom" target="_blank">keystore will be generated</a> in the JKS format (which should not be confused with the .jks file extension). The current up-to-date openjdk environment will give the following warning for such a keystore:</p>
		<p>
				<code>
						<b>The JKS keystore uses a proprietary format. It is recommended to migrate to PKCS12 which is an industry standard format ..."</b>
				</code>
		</p>
		<p>You can probably disregard the warning and install the certificate as usual. Still, to stay on the safe side, you should probably convert the JKS keystore into the PKCS#12 format for the sake of compatibility. You can use the below command to convert this keystore type:</p>
		<p>
				<code>
						<b>keytool -importkeystore -srckeystore yourkeystore.jks -destkeystore yourkeystore.jks -deststoretype pkcs12</b>
				</code>
		</p>
		<p>Where <code><b>yourkeystore.jks</b></code> is the actual name/path to your keystore file.</p>
		<p>Once done, you can check the keystore type by <a href="#5_1">listing the keystore contents</a>.</p>
		<p>The successful output will give a warning stating that the previous keystore in the JKS format was backed up in a separate file:</p>
		<p>
				<code>
						<b>Migrated "yourkeystore.jks" to PKCS12. The JKS keystore is backed up as "yourkeystore.jks.old".</b>
				</code>
		</p>
","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"2020-08-21T11:23:03.0000000","LiveDateTime":"1754-02-02T00:00:00.0000000","CreatedDateTime":"2014-12-11T19:17:46.0000000","ApprovalDatetime":"2014-12-19T17:47:34.0000000","RequestCount":49934,"MarkedAsNew":false,"MarkedAsFeatured":false,"RatingValue":3,"CategoryPaths":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryPathDto","Level":1,"CategoryId":12,"CategoryName":"Hosting"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryPathDto","Level":2,"CategoryId":33,"CategoryName":"SSL Installation"}],"AssociatedCategories":[{"CategoryId":33,"CategoryName":"SSL Installation","CategoryDisplayName":"HostingSSL Installation"}],"AssociatedTags":[],"RelatedArticles":[],"AssociatedMedias":[],"PreferredCategoryId":0,"RootParentCategoryName":null,"RootParentCategoryId":0},"status":200,"statusText":"OK"},"/api/v1/ncpl/simplekb/getcategorybycategoryid:\"{\\\"categoryId\\\":33}\"":{"body":{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryDto","ParentCategoryId":12,"Parent_Category_Name":"Hosting","FriendlyId":null,"ApprovedYN":true,"TreatAsTopicYN":false,"CreatedDateTime":"7/21/2008 4:07:56 PM","CurrentCategoryPaths":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryPathDto","Level":1,"CategoryId":12,"CategoryName":"Hosting"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryPathDto","Level":2,"CategoryId":33,"CategoryName":"SSL Installation"}],"RelatedCategories":[],"AssociatedArticles":[{"ArticleId":9593,"Title":"Installing an SSL certificate on Amazon Web Services (AWS)","ArticleName":"Installing an SSL certificate on Amazon Web Services (AWS)","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"09/02/2020"},{"ArticleId":9595,"Title":"HTTP to HTTPS redirection on IIS","ArticleName":"HTTP to HTTPS redirection on IIS","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/25/2019"},{"ArticleId":9635,"Title":"Installing an SSL certificate on Synology NAS","ArticleName":"Installing an SSL certificate on Synology NAS","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/06/2019"},{"ArticleId":9681,"Title":"Installing an SSL Certificate in Vesta CP","ArticleName":"Installing an SSL Certificate in Vesta CP","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/08/2020"},{"ArticleId":9686,"Title":"Installing an SSL Certificate on Sun Java System Web Server 7.x","ArticleName":"Installing an SSL Certificate on Sun Java System Web Server 7.x","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/28/2019"},{"ArticleId":9702,"Title":"Installing an SSL certificate on Webmin","ArticleName":"Installing an SSL certificate on Webmin","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/06/2019"},{"ArticleId":9705,"Title":"Installing an SSL certificate on Node.js","ArticleName":"Installing an SSL certificate on Node.js","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/08/2019"},{"ArticleId":9746,"Title":"Installing an SSL certificate in Exchange 2013 EAC","ArticleName":"Installing an SSL certificate in Exchange 2013 EAC","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/28/2019"},{"ArticleId":9749,"Title":"Installing an SSL certificate in Exchange 2013 Shell","ArticleName":"Installing an SSL certificate in Exchange 2013 Shell","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/02/2019"},{"ArticleId":9750,"Title":"How to export/import certificates on Exchange 2013 Shell","ArticleName":"How to export/import certificates on Exchange 2013 Shell","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/12/2020"},{"ArticleId":9754,"Title":"Installing an SSL certificate on IIS 8&10","ArticleName":"Installing an SSL certificate on IIS 8&10","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"08/21/2020"},{"ArticleId":9756,"Title":"Installing an SSL certificate on Heroku (paid SSL Endpoint)","ArticleName":"Installing an SSL certificate on Heroku (paid SSL Endpoint)","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/02/2019"},{"ArticleId":9823,"Title":"Installing an SSL certificate on Microsoft Azure Web App","ArticleName":"Installing an SSL certificate on Microsoft Azure Web App","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/26/2020"},{"ArticleId":9825,"Title":"Installing an SSL certificate on a GlassFish application server","ArticleName":"Installing an SSL certificate on a GlassFish application server","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/28/2019"},{"ArticleId":9842,"Title":"Installing an SSL certificate on Zimbra","ArticleName":"Installing an SSL certificate on Zimbra","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/02/2019"},{"ArticleId":9853,"Title":"Installing an SSL certificate on Google App Engine","ArticleName":"Installing an SSL certificate on Google App Engine","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/29/2019"},{"ArticleId":9865,"Title":"Installing an SSL certificate on Exchange 2010","ArticleName":"Installing an SSL certificate on Exchange 2010","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/29/2019"},{"ArticleId":9899,"Title":"Installing an SSL certificate on Mac OS X/Yosemite/El Capitan","ArticleName":"Installing an SSL certificate on Mac OS X/Yosemite/El Capitan","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"02/20/2020"},{"ArticleId":9919,"Title":"Installing an SSL certificate on SonicWall","ArticleName":"Installing an SSL certificate on SonicWall","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/29/2019"},{"ArticleId":9956,"Title":"Installing an SSL certificate on  Plesk Onyx","ArticleName":"Installing an SSL certificate on  Plesk Onyx","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/04/2019"},{"ArticleId":9958,"Title":"Installing an SSL certificate on Citrix NetScaler VPX","ArticleName":"Installing an SSL certificate on Citrix NetScaler VPX","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/29/2019"},{"ArticleId":9970,"Title":"IIS: multiple certificates installation","ArticleName":"IIS: multiple certificates installation","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/29/2019"},{"ArticleId":10026,"Title":"Installing an SSL certificate on XAMPP","ArticleName":"Installing an SSL certificate on XAMPP","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/02/2019"},{"ArticleId":10050,"Title":"Installing an SSL certificate on Heroku SSL","ArticleName":"Installing an SSL certificate on Heroku SSL","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/03/2020"},{"ArticleId":10052,"Title":"Installing an SSL certificate in CWP 7","ArticleName":"Installing an SSL certificate in CWP 7","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/02/2019"},{"ArticleId":10063,"Title":"Installing an SSL certificate on Windows using Certeq","ArticleName":"Installing an SSL certificate on Windows using Certeq","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/02/2019"},{"ArticleId":10134,"Title":"Installing an SSL certificate on Ubiquiti Unifi","ArticleName":"Installing an SSL certificate on Ubiquiti Unifi","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/13/2020"},{"ArticleId":10154,"Title":"Installing an SSL certificate on ISPConfig","ArticleName":"Installing an SSL certificate on ISPConfig","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"08/15/2019"},{"ArticleId":10175,"Title":"Can I install an SSL Certificate on a Parked Domain in cPanel?","ArticleName":"Can I install an SSL Certificate on a Parked Domain in cPanel?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/19/2020"},{"ArticleId":10252,"Title":"How to set up an SSL certificate in SiteWorx account","ArticleName":"How to set up an SSL certificate in SiteWorx account","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/20/2020"},{"ArticleId":10313,"Title":"SSL Certificate installation on httpd (CentOS)","ArticleName":"SSL Certificate installation on httpd (CentOS)","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"01/15/2021"},{"ArticleId":10314,"Title":"SSL Certificate installation on apache2 (Debian, Ubuntu)","ArticleName":"SSL Certificate installation on apache2 (Debian, Ubuntu)","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"09/17/2020"},{"ArticleId":10332,"Title":"Importing/Exporting certificates on Mac OS via Keychain","ArticleName":"Importing/Exporting certificates on Mac OS via Keychain","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/16/2020"},{"ArticleId":633,"Title":"IIS","ArticleName":"IIS","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"12/22/2020"},{"ArticleId":9418,"Title":"Installing an SSL certificate on your server, using cPanel","ArticleName":"Installing an SSL certificate on your server, using cPanel","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/19/2020"},{"ArticleId":9419,"Title":"Installing an SSL certificate on Nginx","ArticleName":"Installing an SSL certificate on Nginx","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/13/2020"},{"ArticleId":9423,"Title":"Installing an SSL certificate on Apache","ArticleName":"Installing an SSL certificate on Apache","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/13/2020"},{"ArticleId":9424,"Title":"Installing an SSL Certificate on IIS 7","ArticleName":"Installing an SSL Certificate on IIS 7","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"12/22/2020"},{"ArticleId":9425,"Title":"Installing an SSL Certificate using DirectAdmin","ArticleName":"Installing an SSL Certificate using DirectAdmin","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/12/2020"},{"ArticleId":9439,"Title":"Installing an SSL Certificate using WHM","ArticleName":"Installing an SSL Certificate using WHM","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/03/2020"},{"ArticleId":9441,"Title":"Installing an SSL certificate on Tomcat","ArticleName":"Installing an SSL certificate on Tomcat","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"08/21/2020"},{"ArticleId":9443,"Title":"Installing an SSL Certificate on Exchange 2007 (PowerShell)","ArticleName":"Installing an SSL Certificate on Exchange 2007 (PowerShell)","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/21/2019"},{"ArticleId":9448,"Title":"Installing an SSL certificate in Plesk 12","ArticleName":"Installing an SSL certificate in Plesk 12","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/14/2020"},{"ArticleId":786,"Title":"What is an SSL certificate and what is it used for?","ArticleName":"What is an SSL certificate and what is it used for?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"10/29/2019"},{"ArticleId":9260,"Title":"Why is it beneficial to have a dedicated IP address?","ArticleName":"Why is it beneficial to have a dedicated IP address?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/12/2019"},{"ArticleId":9259,"Title":"SNI technology","ArticleName":"SNI technology","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"07/06/2018"},{"ArticleId":214,"Title":"Can I install SSL certificates for a couple of domains at once on Namecheap hosting servers?","ArticleName":"Can I install SSL certificates for a couple of domains at once on Namecheap hosting servers?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"11/22/2018"},{"ArticleId":215,"Title":"How many SSL certificates can I install under my Namecheap hosting account?","ArticleName":"How many SSL certificates can I install under my Namecheap hosting account?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"12/28/2020"},{"ArticleId":804,"Title":"SSL certificate activation and installation for domain(s) hosted on Namecheap hosting servers","ArticleName":"SSL certificate activation and installation for domain(s) hosted on Namecheap hosting servers","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"01/20/2021"},{"ArticleId":9393,"Title":"Where do I find SSL CA Bundle?","ArticleName":"Where do I find SSL CA Bundle?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"12/18/2020"},{"ArticleId":211,"Title":"How can I get a CSR code for a domain hosted on Namecheap hosting servers?","ArticleName":"How can I get a CSR code for a domain hosted on Namecheap hosting servers?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"08/31/2020"},{"ArticleId":213,"Title":"Do you allow SSL installation on a subdomain of a domain hosted on Namecheap hosting servers?","ArticleName":"Do you allow SSL installation on a subdomain of a domain hosted on Namecheap hosting servers?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"05/06/2018"},{"ArticleId":9464,"Title":"Can I download an issued certificate on your site?","ArticleName":"Can I download an issued certificate on your site?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"12/07/2020"},{"ArticleId":9465,"Title":"How do I export my certificate from Apache?","ArticleName":"How do I export my certificate from Apache?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"05/27/2016"},{"ArticleId":122,"Title":"Is there a shared SSL certificate for domains hosted on Namecheap hosting servers?","ArticleName":"Is there a shared SSL certificate for domains hosted on Namecheap hosting servers?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"08/31/2020"},{"ArticleId":824,"Title":"How can I renew an SSL certificate for a domain hosted on Namecheap servers?","ArticleName":"How can I renew an SSL certificate for a domain hosted on Namecheap servers?","LiveDateTime":"2/2/1754 12:00:00 AM","NewTillDate":null,"FeaturedTillDate":null,"ModifiedDateTime":"08/26/2020"}],"AssociatedTags":[],"CategoryId":33,"CategoryName":"SSL Installation"},"status":200,"statusText":"OK"},"/api/v1/ncpl/simplekb/getcategories:\"{\\\"parentCategoryId\\\":0,\\\"getTree\\\":true}\"":{"body":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2216,"CategoryName":"Spam Protection"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2217,"CategoryName":"Renewal"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2218,"CategoryName":"cPanel SSL Plugin"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2219,"CategoryName":"PHP Configuration"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2221,"CategoryName":"Multi-Domain SSL Certificates"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2222,"CategoryName":"Cancellation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2223,"CategoryName":"Browser errors"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2224,"CategoryName":"Site Seal, Logo"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2225,"CategoryName":"SEO"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2226,"CategoryName":"Email Migration"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2227,"CategoryName":"SSL Resellers"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":true,"Description":"","ImageUrl":"/assets/img/pictograms/150/cloud-red.png","ShortDesc":"","CategoryId":2228,"CategoryName":"Apps","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2244,"CategoryName":"VPN"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2246,"CategoryName":"How to set up VPN?"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2248,"CategoryName":"Router VPN setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2249,"CategoryName":"Windows built-in VPN setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2251,"CategoryName":"Supersonic CDN"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":177,"CategoryName":"G Suite (Google Apps)"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2229,"CategoryName":"Hosting Resellers"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2232,"CategoryName":"DNSSEC"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2234,"CategoryName":"G Suite (Google Apps)"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2237,"CategoryName":"Host records setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2238,"CategoryName":"SSL installation errors"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/easywp-red.png","ShortDesc":"","CategoryId":2239,"CategoryName":"EasyWP","SubCategories":[]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2244,"CategoryName":"VPN"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2246,"CategoryName":"How to set up VPN?"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2248,"CategoryName":"Router VPN setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2249,"CategoryName":"Windows built-in VPN setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2251,"CategoryName":"Supersonic CDN"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2252,"CategoryName":"InterWorx questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"https://files.namecheap.com/cdn/1055/assets/img/pictograms/150/video-red.png","ShortDesc":"","CategoryId":2253,"CategoryName":"How-To Videos","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2254,"CategoryName":"Domains How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2255,"CategoryName":"Hosting How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2257,"CategoryName":"Sales & Payments How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2258,"CategoryName":"cPanel Email How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2262,"CategoryName":"EasyWP How-To"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2254,"CategoryName":"Domains How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2255,"CategoryName":"Hosting How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2257,"CategoryName":"Sales & Payments How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2258,"CategoryName":"cPanel Email How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2260,"CategoryName":"Private Email Contacts and Calendars Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2253,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2262,"CategoryName":"EasyWP How-To"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":27,"CategoryName":"Getting Started"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/support-red.png","ShortDesc":"","CategoryId":5,"CategoryName":"General & Support","SubCategories":[]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":7,"CategoryName":"Billing FAQ"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":8,"CategoryName":"Transfer Information"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":22,"CategoryName":"Hosting Information"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":38,"CategoryName":"SSL General"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":9,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":45,"CategoryName":"Account Security"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":46,"CategoryName":"Domain Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":63,"CategoryName":"Namecheap API"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2228,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":177,"CategoryName":"G Suite (Google Apps)"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2179,"CategoryName":"Private Email: General Information"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2196,"CategoryName":"WHMCS module for SSL"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/savings-red.png","ShortDesc":"","CategoryId":2200,"CategoryName":"Checkout & Billing","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":7,"CategoryName":"Billing FAQ"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2201,"CategoryName":"Domains Billing"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":21,"CategoryName":"Hosting Billing"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":71,"CategoryName":"SSL Certificates Billing"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2177,"CategoryName":"Private Email"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2201,"CategoryName":"Domains Billing"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":67,"CategoryName":"Activation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":83,"CategoryName":"Transfer to Namecheap"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":9,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":43,"CategoryName":"Profile Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":10,"CategoryName":"DNS Questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":29,"CategoryName":"cPanel questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2215,"CategoryName":"Private Email: Mailbox Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2214,"CategoryName":"Email Forwarding"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":21,"CategoryName":"Hosting Billing"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":11,"CategoryName":"Dynamic DNS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":9,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":44,"CategoryName":"Account Access"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":84,"CategoryName":"Transfer to another provider"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":68,"CategoryName":"Validation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2182,"CategoryName":"cPanel: Software Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2187,"CategoryName":"cPanel: WordPress"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":219,"CategoryName":"Canceled Transfers"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":71,"CategoryName":"SSL Certificates Billing"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2176,"CategoryName":"Private Email: DNS Settings"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":69,"CategoryName":"Installation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/reseller-red.png","ShortDesc":"","CategoryId":34,"CategoryName":"Domains","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2232,"CategoryName":"DNSSEC"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2234,"CategoryName":"G Suite (Google Apps)"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2237,"CategoryName":"Host records setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":46,"CategoryName":"Domain Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":10,"CategoryName":"DNS Questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":11,"CategoryName":"Dynamic DNS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":35,"CategoryName":"Registrations"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2207,"CategoryName":"Renewal questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":36,"CategoryName":"Domains with extended attributes"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":51,"CategoryName":"FreeDNS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":15,"CategoryName":"Marketplace"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2208,"CategoryName":"3rd Party Services Setup"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":35,"CategoryName":"Registrations"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":70,"CategoryName":"Reissuance"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/protection-red.png","ShortDesc":"","CategoryId":37,"CategoryName":"WhoisGuard","SubCategories":[]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2200,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2177,"CategoryName":"Private Email"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2178,"CategoryName":"Private Email: Webmail Features"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2207,"CategoryName":"Renewal questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2210,"CategoryName":"cPanel Add-ons"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2175,"CategoryName":"Private Email: Client Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/status-red.png","ShortDesc":"","CategoryId":2209,"CategoryName":"Domain Transfers","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":8,"CategoryName":"Transfer Information"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":83,"CategoryName":"Transfer to Namecheap"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":84,"CategoryName":"Transfer to another provider"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2209,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":219,"CategoryName":"Canceled Transfers"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":48,"CategoryName":"VPS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":36,"CategoryName":"Domains with extended attributes"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":true,"Description":"","ImageUrl":"/assets/img/pictograms/150/server-red.png","ShortDesc":"","CategoryId":12,"CategoryName":"Hosting","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2219,"CategoryName":"PHP Configuration"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2225,"CategoryName":"SEO"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2252,"CategoryName":"InterWorx questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":27,"CategoryName":"Getting Started"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":22,"CategoryName":"Hosting Information"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":29,"CategoryName":"cPanel questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2182,"CategoryName":"cPanel: Software Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2187,"CategoryName":"cPanel: WordPress"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2210,"CategoryName":"cPanel Add-ons"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":48,"CategoryName":"VPS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2188,"CategoryName":"Dedicated Server"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":30,"CategoryName":"WHM questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":32,"CategoryName":"DNS settings"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":103,"CategoryName":"LVE (CloudLinux)"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":89,"CategoryName":"SSH Access"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":205,"CategoryName":"FTP questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2180,"CategoryName":"MySQL questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2199,"CategoryName":"Hosting Migration"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2194,"CategoryName":"Tips & Tricks"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":239,"CategoryName":"WHMCS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":33,"CategoryName":"SSL Installation"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2171,"CategoryName":"Private Email: Active Sync (Exchange) Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2188,"CategoryName":"Dedicated Server"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":30,"CategoryName":"WHM questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":31,"CategoryName":"cPanel Email FAQs"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":51,"CategoryName":"FreeDNS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/email-red.png","ShortDesc":"","CategoryId":93,"CategoryName":"Email service","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2216,"CategoryName":"Spam Protection"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2226,"CategoryName":"Email Migration"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2260,"CategoryName":"Private Email Contacts and Calendars Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2179,"CategoryName":"Private Email: General Information"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2215,"CategoryName":"Private Email: Mailbox Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2214,"CategoryName":"Email Forwarding"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2176,"CategoryName":"Private Email: DNS Settings"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2178,"CategoryName":"Private Email: Webmail Features"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2175,"CategoryName":"Private Email: Client Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2171,"CategoryName":"Private Email: Active Sync (Exchange) Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":31,"CategoryName":"cPanel Email FAQs"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2186,"CategoryName":"cPanel Email: Client Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2204,"CategoryName":"Private Email: Video Overview"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":32,"CategoryName":"DNS settings"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":15,"CategoryName":"Marketplace"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2186,"CategoryName":"cPanel Email: Client Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":34,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2208,"CategoryName":"3rd Party Services Setup"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":93,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2204,"CategoryName":"Private Email: Video Overview"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/security-red.png","ShortDesc":"","CategoryId":14,"CategoryName":"SSL Certificates","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2217,"CategoryName":"Renewal"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2218,"CategoryName":"cPanel SSL Plugin"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2221,"CategoryName":"Multi-Domain SSL Certificates"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2222,"CategoryName":"Cancellation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2223,"CategoryName":"Browser errors"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2224,"CategoryName":"Site Seal, Logo"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2238,"CategoryName":"SSL installation errors"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":38,"CategoryName":"SSL General"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":67,"CategoryName":"Activation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":68,"CategoryName":"Validation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":69,"CategoryName":"Installation"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":14,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":70,"CategoryName":"Reissuance"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":true,"Description":"","ImageUrl":"/assets/img/pictograms/150/performance-red.png","ShortDesc":"","CategoryId":9,"CategoryName":"My Account","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":9,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":45,"CategoryName":"Account Security"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":9,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":43,"CategoryName":"Profile Management"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":9,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":44,"CategoryName":"Account Access"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":103,"CategoryName":"LVE (CloudLinux)"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/affiliates-red.png","ShortDesc":"","CategoryId":55,"CategoryName":"Affiliates","SubCategories":[]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":89,"CategoryName":"SSH Access"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/tools-red.png","ShortDesc":"","CategoryId":2211,"CategoryName":"API & Resellers","SubCategories":[{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2227,"CategoryName":"SSL Resellers"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2229,"CategoryName":"Hosting Resellers"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":63,"CategoryName":"Namecheap API"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":2211,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2196,"CategoryName":"WHMCS module for SSL"}]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/timer-red.png","ShortDesc":"","CategoryId":2212,"CategoryName":"Legacy Products","SubCategories":[]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":205,"CategoryName":"FTP questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2180,"CategoryName":"MySQL questions"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2199,"CategoryName":"Hosting Migration"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":0,"TreatAsTopicYN":false,"Description":"","ImageUrl":"/assets/img/pictograms/150/premiumdns-red.png","ShortDesc":"","CategoryId":2231,"CategoryName":"PremiumDNS","SubCategories":[]},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":2194,"CategoryName":"Tips & Tricks"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":239,"CategoryName":"WHMCS"},{"__type":"Nc:SimpleKB:Abstractions:Dtos:CategoryItemDto","ParentCategoryId":12,"TreatAsTopicYN":false,"Description":"","ImageUrl":"","ShortDesc":"","CategoryId":33,"CategoryName":"SSL Installation"}],"status":200,"statusText":"OK"}}

Installing an SSL certificate on Tomcat

This guide is intended for those with Apache Tomcat set up with your website running on either default port 8080 or 80 via the HTTP protocol. Once this condition is met, SSL installation can be initiated.

Tomcat provides you with quite a flexible way of installing SSL, unlike most other servers. SSL certificates can be installed through either APR (Apache Portable Runtime) or JSSE (Java Secure Socket Extension) connectors. The JSSE method is the most widely used connector that includes interaction with Java keystores created via keytool. APR simplifies SSL installation to the usual Apache-like process.

Prerequisites

Make sure that you have issued and active SSL certificate files prepared prior to proceeding with SSL installation. You can download the active certificate from your account directly.

If the CSR was generated using the keytool on your server, you can stick to the PKCS7 installation steps. If you generated the CSR elsewhere and have the matching Private key, use the PKCS12 or APR-based installation.

Important: If you have separate Private key and certificate files, you will need to convert them into a PKCS#12 file first, unless there is an APR configured along with your Tomcat. Once the files are converted, you can proceed with the respective PKCS#12 installation steps.

Java keystores

After you have created a keystore containing the Private key along with the corresponding CSR, you will need to import your issued SSL certificate into the keystore under the main keystore alias. Each time you interact with a keystore file, you will need to enter its password. Below is an overview of all the possible ways of adding a certificate to your keystore.

PKCS#7

The most time-efficient way to install your SSL on Tomcat from a keystore is to use a PKCS#7 formatted certificate (a file with the .p7b or .cer extension).

Step 1: Upload SSL files

Upload the PKCS#7 certificate file on the server. Then, import it using the following command:

keytool -import -trustcacerts -alias tomcat -file certificate.p7b -keystore yourkeystore.jks

Where:

  • tomcat is the actual alias of your keystore
  • certificate.p7b is the actual name/path to your certificate file
  • yourkeystore.jks is the actual name/path to the keystore file

Make sure the certificate file has the same alias used for creating the keystore. Otherwise, the “Input not an X.509 certificate” error may take place.

After you have imported successfully, you should receive the following output:

Certificate reply was installed in keystore

Step 2: Edit SSL Configuration

In the next step, you will need to modify the connector for the default port 8443 or 443.

The modification should be done in the ‘Tomcat installation directory’/conf/server.xml file. You can find the location of the directory containing the server.xml configuration file by issuing this command:

sudo find / -ipath '*tomcat*server.xml'

It will most likely be in /opt/tomcat/conf/server.xml or /etc/tomcat/server.xml

Here is an example of a JSSE connector for port 443 using the HTTP/1.1 protocol with TLS up to 1.3 enabled:

<Connector
protocol="org.apache.coyote.http11.Http11NioProtocol"
port="443"
maxThreads="200"
scheme="https"
secure="true"
SSLEnabled="true"
keystoreFile="/opt/tomcat/ssl/yourkeystore.jks"
keystorePass="keystore_password"
clientAuth="false"
sslProtocol="TLS"/>

Where:

  • /opt/tomcat/ssl/yourkeystore.jks is the absolute path and actual name of the keystore file
  • keystore_password is the actual password for your keystore

Step 3: Apply changes

Once done, please restart Tomcat in order to apply the changes. If you are not quite sure about the steps to reproduce, feel free to jump to this section to apply the changes and verify SSL installation.


PEM

The most challenging, yet still common, way of installing an SSL certificate on Tomcat is by using separate PEM-formatted SSL certificates.

Step 1: Prepare the files

This method requires you to have each of the certificates saved in separate files:

  1. CA root certificate.
  2. CA second intermediate certificate (optional and can be omitted if your CA bundle contains only 1 intermediate certificate).
  3. CA intermediate certificate.
  4. End-entity certificate for your domain.

The order of the certificate will be as follows for the most frequently used PositiveSSL certificate:

keytool -import AAA Certificate Services
keytool -import USERTrust RSA Certification Authority
keytool -import Sectigo RSA Domain Validation Secure Server CA
keytool -import example.com.crt

Note: You can find more CA Bundles here.

Note: The “AAA Certificate Services” is only installed if you chose the CA Bundle containing the cross-signed certificate.

The above list is composed in reverse order on purpose as this is the exact order in which the certificates should be imported to the keystore. You can download the certificate files from your Namecheap account along with the CA bundle. Here is the dedicated page with download links if you only need the CA bundle. It may come in handy if you encounter the “keytool error: java.langException: Failed to establish chain from reply” error.

Step 2: Import the files

Follow the below steps in the given order to import the files properly.

Import the root certificate by running:

keytool -import -trustcacerts -alias root -file root.crt -keystore yourkeystore.jks

Where:

  • root is the alias of the imported CA root certificate
  • root.crt is the actual name/path of your CA root certificate
  • yourkeystore.jks is the actual name/path of the keystore file

Note: During import of the CA root certificate, you may be prompted with the following message.

Certificate already exists in system-wide CA keystore under alias <aliasname>
Do you still want to add it to your own keystore? [no]:

Disregard the warning and confirm certificate import with submitting y.

Import the second intermediate certificate:

keytool -import -trustcacerts -alias intermediate2 -file intermediate_2.crt -keystore yourkeystore.jks

Where:

  • intermediate2 is the alias of the imported second intermediate CA certificate
  • intermediate_2.crt is the actual name/path of your second intermediate CA certificate

Import the first intermediate certificate:

keytool -import -trustcacerts -alias intermediate1 -file intermediate_1.crt -keystore yourkeystore.jks

Where:

  • intermediate1 is the alias of the imported first intermediate CA certificate
  • intermediate_1.crt is the actual actual name/path of your first intermediate CA certificate

After the successful import of each of the above certificates, you should receive the following output:

Certificate was added to keystore

Import the end-entity certificate for your domain:

keytool -import -trustcacerts -alias tomcat -file certificate.crt -keystore yourkeystore.jks

Where:

  • tomcat is the actual alias of your keystore. The alias for your end-entity certificate should be the same as the one you used when creating the keystore with the Private key. If you did not specify the alias during the keystore creation, the default value will be mykey.
  • certificate.crt is the actual actual name/path of your end-entity certificate file.

After import of the end-entity certificate, the below message will be prompted:

Certificate reply was installed in keystore

Step 3: Edit the connector

In the next step, you will need to modify the connector for the default port 8443 or 443.

The modification should be done in the ‘Tomcat installation directory’/conf/server.xml file. You can find the location of the directory containing the server.xml configuration file by issuing the below command:

sudo find / -ipath '*tomcat*server.xml'

Most likely, it will be in /opt/tomcat/conf/server.xml or /etc/tomcat/server.xml

Here is an example of the JSSE connector for port 443 using HTTP/1.1 protocol along with TLS up to 1.3 protocol versions:

<Connector
protocol="org.apache.coyote.http11.Http11NioProtocol"
port="443"
maxThreads="200"
scheme="https"
secure="true"
SSLEnabled="true"
keystoreFile="/opt/tomcat/ssl/yourkeystore.jks"
keystorePass="keystore_password"
clientAuth="false"
sslProtocol="TLS"/>

Where:

  • /opt/tomcat/ssl/yourkeystore.jks is the absolute path and actual name of the keystore file
  • keystore_password is the actual password for your keystore

Step 4: Enforce the changes

Once done, please restart Tomcat in order to apply changes.If you are not quite sure about the steps to reproduce, you can go to this section to apply the changes and verify SSL installation.


PKCS#12

If you have no APR enabled on Apache Tomcat, this method of SSL installation is the optimal balance between the PKCS#7 and PEM import methods. PKCS#12 is a certificate standard when all the required parts (end-entity certificate for the hostname, CA bundle, and the Private key) are stored in the same file.

Step 1: Prepare the SSL files

Feel free to jump right to the next part if you already have a PKCS#12 (.pfx/.p12) certificate. If you do not have one, convert the corresponding files first.

Step 2: Modify the keystore

PKCS#12 file is considered as a keystore in itself. Thus, you will just need to specify the path to the PKCS#12 file in the keystoreFile directive. The process is pretty much the same as for the PKCS7 and PEM standards.

The modification should be done in the ‘Tomcat installation directory’/conf/server.xml file. You can find the location of the directory containing the server.xml configuration file by issuing the below command:

sudo find / -ipath '*tomcat*server.xml'

It will most likely be in /opt/tomcat/conf/server.xml or /etc/tomcat/server.xml.

Here is an example of PKCS#12 JSSE connector for port 443 using HTTP/1.1 protocol along with TLS up to 1.3 protocol versions:


<Connector
protocol="org.apache.coyote.http11.Http11NioProtocol"
port="443"
maxThreads="200"
scheme="https"
secure="true"
SSLEnabled="true"
keystoreFile="/opt/tomcat/ssl/somefile.pfx"
keystorePass="password_from_your_pfx"
keystoreType="PKCS12"
clientAuth="false"
sslProtocol="TLS"/>

Where:

  • /opt/tomcat/ssl/somefile.pfx is the absolute path and actual name for the PKCS#12 certificate
  • password_from_your_pfx is the actual password for the PKCS#12 file
Note: In all cases when you use PKCS12 file, the "keystoreType" directive should be specified in the SSL configuration to define that the keystore format is PKCS#12 for the server to read the file properly.

Step 3: Complete the SSL installation

Once done, please restart Tomcat in order to apply changes. If you are not quite sure about the steps to reproduce, skip to this section to apply the changes and verify SSL installation.


APR-based installation

Most Linux distributions ship packages for APR out-of-the-box. Still, additional libtcnative, libapr1-dev and libssl-dev packages are required for APR to function properly with Tomcat (if you do not have installed them yet). Tomcat Native libraries also need to be compiled. We do not address this topic in this guide; it’s assumed you already have APR set up with Tomcat. If no APR is set up on your Apache Tomcat, check out this installation method.

Step 1: Upload files

First, upload the certificate, the Private key, and the CA bundle (if the Certificate Signing Request was generated elsewhere) to the server.

Step 2: Configure the connector

Next, modify the existing connector for the default port 8443 or 443. The modification should be done in the ‘Tomcat installation directory’/conf/server.xml file.

You can find the location of the directory containing the server.xml configuration file by issuing below command:

sudo find / -ipath '*tomcat*server.xml'

It will most likely be in /opt/tomcat/conf/server.xml or /etc/tomcat/server.xml

Here is an example of the APR connector for the port 443 using HTTP/1.1 protocol along with TLS1.1 & TLS1.2 enabled:

<Connector
protocol="org.apache.coyote.http11.Http11AprProtocol"
port="443"
maxThreads="200"
scheme="https"
secure="true"
SSLEnabled="true"
SSLCertificateFile="/opt/tomcat/ssl/cert.crt"
SSLCertificateChainFile="/opt/tomcat/ssl/bundle.ca-bundle"
SSLCertificateKeyFile="/opt/tomcat/ssl/private.key"
SSLVerifyClient="optional"
SSLProtocol="TLSv1.1+TLSv1.2"/>

Where:

  • /opt/tomcat/ssl/cert.crt is the absolute path and actual name of the PEM-formatted certificate
  • /opt/tomcat/ssl/bundle.ca-bundle is the absolute path and actual name of the CA bundle file
  • /opt/tomcat/ssl/private.key is the absolute path and actual name of the Private key file

Important Note: The APR connector requires you to set the SSLCertificateChainFile directive explicitly. It isn’t possible to install the certificate properly with a single file containing both the end-entity certificate and CA bundle chain, like it is usually done on Apache 2.4.8 and above. If only the SSLCertificateFile is set in the connector, the first certificate from the file will be retrieved during handshake, which could possibly trigger the ERR_CERT_AUTHORITY_INVALID error.

Important: Access permissions settings

When installing a certificate for the APR connector, you may encounter the following error message:

WARNING [main] org.apache.tomcat.util.net.openssl.OpenSSLContext.init Error initializing SSL context java.lang.Exception: Unable to load certificate key /opt/tomcat/ssl/private.key (error:0200100D:system library:fopen:Permission denied)

It is caused by improper access permissions set for the certificate and Private key files. You need to make your tomcat user the owner of the certificate and Private key files. Use the following commands to accomplish this:

sudo chown tomcat /etc/ssl/private.key /etc/ssl/cert.crt

Where /opt/tomcat/ssl is the directory containing the respective certificate and Private key files, and tomcat is your tomcat user.

Be aware that Tomcat is permission-sensitive, thus it will not be possible to use certificate & Private key or keystore files saved in the /root or similar access-restricted directories.


Step 3: Apply the changes

Once done, please restart Tomcat in order to apply changes. If you are not quite sure about the steps to reproduce, feel free to jump to this section to apply the changes and verify SSL installation.


Apply the changes

Save the changes and restart Tomcat either via the systemd service if there is any available, like so:

sudo systemctl restart tomcat

Or by using binaries. These will most likely be found in the following location:

/opt/tomcat/bin/shutdown.sh
/opt/tomcat/bin/startup.sh

However, the location of Tomcat binaries may vary between installations. You can find the location of both the startup and shutdown binary files by executing the below command:

sudo find / -ipath '*tomcat*\/s[h t]*.sh'

You will have 2 files in the output. They should be used for restarting Tomcat. Run the below commands in the following order to restart the server:

sudo sh /opt/tomcat/bin/shutdown.sh
sudo sh /opt/tomcat/bin/startup.sh

Where:

  • /opt/tomcat/bin/shutdown.sh is the absolute path to the shutdown.sh file from the previous output
  • /opt/tomcat/bin/startup.sh is the absolute path to the startup.sh file from the previous output

Once restarted, feel free to check the SSL installation using this online tool.


Troubleshooting

View keystore content

Use this command to check the imported decoded certificates in the keystore. For each correctly-imported certificate, you will see its details in a keystore entry. The Private key entry is displayed in the list as well:

keytool -list -keystore yourkeystore.jks -v

The output should be similar to the below listing:

$ keytool -list -keystore yourkeystore.jks -v
Enter keystore password:
Keystore type: PKCS12
Keystore provider: SUN


Your keystore contains 4 entries




Alias name: tomcat
Creation date: Mar 13, 2020
Entry type: PrivateKeyEntry
Certificate chain length: 4
Certificate[1]:
Owner: CN=example.com
Issuer: CN=Sectigo RSA Domain Validation Secure Server CA, O=Sectigo Limited, L=Salford, ST=Greater Manchester, C=GB
Serial number: 45<...>76
Valid from: Fri Mar 13 00:00:00 UTC 2020 until: Tue Mar 09 23:59:59 UTC 2021
Certificate fingerprints:
SHA1: 4A:BA<...>67:BE
SHA256: D8:9D<...>3D:D3
Signature algorithm name: SHA256withRSA
Subject Public Key Algorithm: 2048-bit RSA key
Version: 3

To view the keystore content with respective encoded certificates in plain text (RFC-style), use the below command:

keytool -list -rfc -keystore yourkeystore.jks

The output should be similar to the below listing:

$ keytool -list -rfc -keystore yourkeystore.jks
Enter keystore password:
Keystore type: PKCS12
Keystore provider: SUN


Your keystore contains 4 entries




Alias name: tomcat
Creation date: Mar 13, 2020
Entry type: PrivateKeyEntry
Certificate chain length: 4
Certificate[1]:
-----BEGIN CERTIFICATE-----
MIIFvTCCBKWgAwIBAgIQRQgwqjjPDLDCtR8R7NN1djANBgkqhkiG9w0BAQsFADCB
...
6NB/mQXfhuiyeBSe4jTmr4nja6JXvjQU1GUOgrv08KuU
-----END CERTIFICATE-----


Extract Private key from keystore

It is not possible to extract the Private key from a keystore directly, but there is a workaround with OpenSSL. You will need to:

  1. Convert the Java keystore file into the PKCS#12 standard file;
  2. Get the PKCS#12 file converted into a separate PEM encoded Private key file, i.e. export the Private key;
  3. View the content of the newly created Private key file.

Follow the below commands to start the process:

  1. keytool -importkeystore -srckeystore yourkeystore.jks -destkeystore somefile.pfx -srcstoretype JKS -deststoretype PKCS12 -deststorepass password_from_your_pfx
  2. Note:

    Some Java versions running Tomcat (or another servlet container using keytool as a Private/Public keys management shell) have different prefered file extensions for PKCS#12 (e.g. older versions like JDK 1.6 and earlier can generate .p12 files). The current stable versions usually generate .pfx files. The file content of .p12 and .pfx files are essentially the same.
  3. openssl pkcs12 -in somefile.pfx -out private.key -nocerts -nodes
  4. cat private.key

Be aware that the exported Private key may contain additional attributes (such as Bag Attributes or Key Attributes) along with the key code itself. In the output file, feel free to remove the first ~4 lines standing before the -----BEGIN PRIVATE KEY----- tag.


Proprietary keystore format warning

If you have a JDK version older than version 9 installed, the keystore will be generated in the JKS format (which should not be confused with the .jks file extension). The current up-to-date openjdk environment will give the following warning for such a keystore:

The JKS keystore uses a proprietary format. It is recommended to migrate to PKCS12 which is an industry standard format ..."

You can probably disregard the warning and install the certificate as usual. Still, to stay on the safe side, you should probably convert the JKS keystore into the PKCS#12 format for the sake of compatibility. You can use the below command to convert this keystore type:

keytool -importkeystore -srckeystore yourkeystore.jks -destkeystore yourkeystore.jks -deststoretype pkcs12

Where yourkeystore.jks is the actual name/path to your keystore file.

Once done, you can check the keystore type by listing the keystore contents.

The successful output will give a warning stating that the previous keystore in the JKS format was backed up in a separate file:

Migrated "yourkeystore.jks" to PKCS12. The JKS keystore is backed up as "yourkeystore.jks.old".

Updated

Viewed
49934 times

{}

Need help? We're always here for you.