Recently I changed my nginx configuration to support Client Certificates to login in to services through the Web from outside my internal network. This will be broken down in to mutable parts so that it is easier to read.
- Creating Client Certificates
- Configuring haproxy to accept them
- Configuring haproxy to reverse proxy to your web applications
- Adding your Client Certificate to your browser
####Creating Client Certificates This is a tutorial on creating your self signed Client Certificate. Unlike self signed Certificates their is no ugly page saying that this is not signed by a secure Third Party which is good for us.
#####Create a Certificate Authority root This command creates a Certificate Authority so we can sign the Client Certificate.
openssl genrsa -des3 -out ca.key 4096
openssl req -new -x509 -days 365 -key ca.key -out ca.crt
Organization & Common Name is the DNS name of the server. What I did is create a wild star so that I can use it for other projects later on down the road.
Create the Client Key and CSR
This Command creates the Client Certificate and signs it with the Certificate Authority that we created in the last section.
openssl genrsa -des3 -out client.key 4096
openssl req -new -key client.key -out client.csr
openssl x509 -req -days 365 -in client.csr -CA ca.crt -CAkey ca.key -set_serial 01 -out client.crt
Organization & Common Name can be anything you want but I ususaly keep it as the username of the Person that will use it
Convert Client Key to PKCS
Most browsers accept PKCS#12 as the format for Client Keys. This command will convert the client cert in to PKCS#12 format.
openssl pkcs12 -export -clcerts -in client.crt -inkey client.key -out client.p12
Convert Client Key to (combined) PEM
This command combinds client.p12
certificate and client.key
private key into a single PEM file for programs using openssl.
openssl pkcs12 -in client.p12 -out client.pem -clcerts
Continue to Part2