Moving SSL Certificate from IIS to Apache

This procedure will help you to move or copy your SSL certificate, installed on an IIS server to an Apache server.

Step 1: Export IIS certificate into a .PFX file

  • Run mmc.exe
  • Click the ‘Console’ menu and then click ‘Add/Remove Snap-in’.
  • Click the ‘Add’ button and then choose the ‘certificates’ snap-in and click on ‘Add’.
  • Select ‘Computer Account’ then click ‘Next’.
  • Select ‘Local Computer’ and then click ‘OK’.
  • Click ‘Close’ and then click ‘OK’.
  • Expand the menu for ‘Certificates’ and click on the ‘Personal’ folder.
  • Right click on the certificate that you want to export and select ‘All tasks’ -> ‘Export’.
  • A wizard will appear. Make sure you check the box to include the private key and continue through with this wizard until you have a .PFX file.

Step 2: Extract the private key

Export the private key file from the .PFX file.

$ openssl pkcs12 -in filename.pfx -nocerts -out key.pem

Step 3: Extract the certificate file

Export the certificate file from the .PFX file.

$ openssl pkcs12 -in filename.pfx -clcerts -nokeys -out cert.pem

Step 4: Remove the passphrase

This command removes the passphrase from the private key so Apache won’t prompt you for your passphase when it starts.

$ openssl rsa -in key.pem -out server.key

Extra Steps

Make sure that the following lines are present in your apache virtual host configuration file and they are correct:

SSLEngine on
SSLOptions +StrictRequire
SSLCertificateFile /path/to/certificate/cert.pem
SSLCertificateKeyFile /patch/to/key/server.key

Don’t forget to restart apache at the end.

0 (0)
Article Rating (No Votes)
Rate this article
Attachments
There are no attachments for this article.
Comments
There are no comments for this article. Be the first to post a comment.
Full Name
Email Address
Security Code Security Code
Related Articles RSS Feed
How to Analyze or Read OS Watcher Output in three easy steps -- With Example ?
Viewed 41861 times since Thu, Jun 21, 2018
RHCS6: Debug and test multicast traffic between two hosts
Viewed 6743 times since Sun, Jun 3, 2018
LVM: Move allocated PE between Physical Volumes
Viewed 3977 times since Sat, Jun 2, 2018
How to disable SSH cipher/ MAC algorithms for Linux and Unix
Viewed 47049 times since Fri, Aug 21, 2020
Zabijanie wszystkich procesów użytkownika
Viewed 2760 times since Thu, May 24, 2018
List DNS records, nameservers of a domain from command line
Viewed 2066 times since Sun, Sep 30, 2018
How to recover error - Audit error: dispatch err (pipe full) event lost
Viewed 25986 times since Tue, Aug 6, 2019
Df command in Linux not updating actual diskspace, wrong data
Viewed 2962 times since Wed, May 30, 2018
RHEL: Enabling standard ftp/telnet
Viewed 3555 times since Sun, May 27, 2018
Manage Linux Password Expiration and Aging Using chage
Viewed 4709 times since Tue, Sep 11, 2018