Formally known as Secure Sockets Layer (SSL), nowadays it has become increasingly important as a result to keep data protected by establishing an encrypted link between a server and a client.
This is the first in a series of posts about Using SSL on a Sitecore environment, I hope you enjoy it.
In today’s post, I’ll show an overview of SSL, how to create a self-signed certificate and import on IIS.
A handshake says it all
The processes running behind the scenes when you attempt to access a secure website is known as SSL Handshake. And as you can see illustrated below, there are 5 steps to establish a secure connection between client and server.
Many flavors, but only one purpose: protect your data!
You will find SSL in a number of different flavors (Wildcard, SAN and etc) , each with their own particularities, so choose them accordingly to your organization needs.
- Single Domain
Only a single domain is protected, for example yourdomain.com
- Subject Alternative Names
Multiple domains in the same certificate, for example yourdomain.com and differentdomain.com
- Wildcard
All domain secured, for example *.mydomain.com secures www.mydomain.com and services.mydomain.com
Trust in yourself
You can always rely on self-signed certificates to replicate in your own environment the effect of SSL can cause in your website! However, keep in mind that others won’t trust you as you do – which means that you MUST avoid use self-signed in production solutions.
You probably saw many self-signed creators, and since Windows 8 there’s a cmdlet in Powershell called New-SelfSignedCertificate that gives a easier experience to create self-signed certificates than any other tool.
In order to use the follow commands, you must have at least Windows 8
Step 1 – Create a Self-signed certificate
1. Run Windows Powershell as Administrator
2. Type the follow command, then hit enter
New-SelfSignedCertificate -DnsName mydomain.com -CertStoreLocation cert:\LocalMachine\My
3. You should receive a similar output, as you can see in the image below
data:image/s3,"s3://crabby-images/2edcb/2edcb5acfcef956c3a51f948f369881bc407bb78" alt="New SelfSignedCertificate Powershell Blog Vinicius Deschamps"
Step 2 – Use Self-Signed Certificate on IIS
1. Open IIS, expand sites
data:image/s3,"s3://crabby-images/6a769/6a769fe96732b6064655e045b2d110f5ca992145" alt="IIS Internet Information Services Expand Site Blog Vinicius Deschamps"
2. Select the Site you want to use Self-Signed certificate, right-click on it then Edit Bindings
data:image/s3,"s3://crabby-images/a1f34/a1f3448b915a181757b780c7a5feb0924bad834b" alt="IIS Internet Information Services Edit Bindings Blog Vinicius Deschamps"
3. In Site Bindings, click Add
data:image/s3,"s3://crabby-images/7a6ab/7a6ab15b4187b106d8f6c1c76f3521308447346d" alt="IIS Sitecore Site Bindings Add Blog Vinicius Deschamps"
4. In Add Site Binding, choose Type HTTPS and on SSL certificate choose the certificate create in Step 1, and click Ok then Close (Site Bindings window)
data:image/s3,"s3://crabby-images/161ef/161ef2a9e5775f72103c2abaa1a1e3e9290692f1" alt="IIS Internet Information Services Add Site Binding SSL Certificate Blog Vinicius Deschamps"
Please note that I already have mydomain.com in my hosts file (C:\Windows\System32\drivers\etc\hosts) pointing to 127.0.0.1
data:image/s3,"s3://crabby-images/d67f7/d67f7e7df4cabd3a7274585d79f8102145409bdf" alt="C:\Windows\System32\drivers\etc\hosts Blog Vinicius Deschamps"
5. Go to your browser and access your website using the domain used on –DnsName parameter on Step 1, in my case was mydomain.com, so https://mydomain.com
data:image/s3,"s3://crabby-images/67999/67999801ee77fc19530a6f546d4429754fa254b2" alt="Sitecore Your connection is not private Blog Vinicius Deschamps"
Step 3 (PLUS!!!) – Export Self-Signed certificate as PFX file with a password
In case you want to install on another machine or send to a colleague
1. In the same Windows Powershell, copy Self-Signed Thumbprint and keep it (in my case AB34CF46EF6DAAE6FCB69C65F4A9C07710644F3F)
data:image/s3,"s3://crabby-images/84f21/84f21556b29b23b2c4d2533b6fe9b47d7cecea6b" alt="Sitecore Thumbprint output Powershell Blog Vinicius Deschamps"
2. Create a password using the following command
$sslPassword = ConvertTo-SecureString "P@ssw0rd" -Force -AsPlainText
3. Export the certificate as PFX file using the command below
Export-PfxCertificate -Cert cert:\LocalMachine\My\AB34CF46EF6DAAE6FCB69C65F4A9C07710644F3F -FilePath C:\temp\mydomain.pfx -Password $sslPassword
4. You should receive a similar output, as you can see in the image below
data:image/s3,"s3://crabby-images/961ac/961ac2c6a4f8232c5fe64407a1fba33ac926735a" alt="Export PFXCertificate Powershell Blog Vinicius Deschamps"
5. Navigate to the folder you saved the PFX file and check if it was created. In my case, it was on C:\temp
data:image/s3,"s3://crabby-images/849b0/849b0c78e2c59a4960164735f8c7a64d0221b1b4" alt="PFX Certificate Exported Blog Vinicius Deschamps"
Step 4 (PLUS!!!) – Stop receiving SSL errors with Self-Signed certificates
1. Execute the Step 3 and get yourself a PFX file
2. Press Windows+R to open Run, type mmc in the empty box and click Ok
data:image/s3,"s3://crabby-images/06869/0686910d24f3943c74535d1c660439870a3ce27c" alt="Run MMC Blog Vinicius Deschamps"
3. Click Yes in the User Account Control window
4. On the File menu, click Add/Remove Snap In
data:image/s3,"s3://crabby-images/107a2/107a2247586243d3778735fa1d880061e8460778" alt="MMC Add Remove Snap-in Blog Vinicius Deschamps"
5. Under Available snap-ins, double-click Certificates
data:image/s3,"s3://crabby-images/d1b79/d1b79c2f430bba68b542035a9becd787075dd651" alt="Add Remove Snap-ins Certificate Blog Vinicius Deschamps"
6. Select Computer Account, and then click Next
data:image/s3,"s3://crabby-images/7b53a/7b53a9b1d5d197d0ce9f2f79505c7a7583bfbdb9" alt="Certificates Snap-in Computer Account Blog Vinicius Deschamps"
7. Keep Local Computer on Select Computer window, and then click Finish
data:image/s3,"s3://crabby-images/bfc13/bfc1342e34e370a8ca694af798e86d456f534f29" alt="Select Computer Local Computer Blog Vinicius Deschamps"
8. Click Ok on Add or Remove Snap-ins
data:image/s3,"s3://crabby-images/30087/300871462a87ce4576a4690433afafe3d93b621f" alt="Add Remove Snap-ins Selected OK Blog Vinicius Deschamps"
9. Expand Certificates, find and right-click in Trusted Root Certification then choose Import
data:image/s3,"s3://crabby-images/2db8b/2db8b68a74f97624445f0dc0db175d1df036187e" alt="MMC Certificates Trusted Root Certification Import Blog Vinicius Deschamps"
10. Welcome to the Certificate Import Wizard screen, click Next
data:image/s3,"s3://crabby-images/c51f2/c51f21d93d9a89c71cf8868eb0c4914d9bd954ef" alt="Certification Import Wizard Welcome Blog Vinicius Deschamps"
11. File to import window click in Browse…
data:image/s3,"s3://crabby-images/41d5d/41d5d72eb1764e984e7f1e03c0d7dedb2ea72e35" alt="File to import Blog Vinicius Deschamps"
12. At the bottom right change the Certificate file to Personal Information Exchange (*.pfx, *.p12)
data:image/s3,"s3://crabby-images/5b862/5b862536bf1b45acf4fa3ccf51a6b26da5834bf3" alt="Open Personal Information Exchange P12 PFX Blog Vinicius Deschamps"
13. Navigate to the folder where you exported the PFX file in Step 3 and select it, and then click Open
data:image/s3,"s3://crabby-images/5222d/5222dbcee5d7884c2a5f95cd22a3d5ac8fa49ebd" alt="Choose PFX Certificate Blog Vinicius Deschamps"
14. Private key protection window, type the same Password you used to export the PFX file in Step 3 and click Next
data:image/s3,"s3://crabby-images/9d5af/9d5af63a8373c9e4128e5e246eafbbe033663b83" alt="Private Key Protection Blog Vinicius Deschamps"
15. Double check the certificate will be placed at Trusted Root Certification Authorities, and click Next, then Finish
data:image/s3,"s3://crabby-images/2a0c9/2a0c90f967a13c303bf0b82267ce5362c3ba7af0" alt="Certification Store Trusted Root Certification Authorities Blog Vinicius Deschamps"
16. Restart any browser you have open, and test again
data:image/s3,"s3://crabby-images/8668e/8668e92921e6471de436613a322148f929fa6a54" alt="Sitecore Experience Platform Fresh Installation SSL Blog Vinicius Deschamps"
Voilá! You are not seeing the error anymore!
Thanks for reading, and I hope you enjoyed!
I’ll see you on the next post!
Deixe um comentário