環境爲CentOS 7.三、httpd2.4.6html
說明:數據庫
CA 主機爲192.168.29.3 client主機爲 192.168.29.100
[root@centos7 ~]# (umask 077 ; openssl genrsa -out /etc/pki/CA/private/cakey.pem 4096) Generating RSA private key, 4096 bit long modulus .....................++ ...........................................................................................................................................................................................++ e is 65537 (0x10001)
[root@centos7 ~]# openssl req -new -x509 -key /etc/pki/CA/private/cakey.pem -out /etc/pki/CA/cacert.pem -days 365 You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ----- Country Name (2 letter code) [XX]:CN State or Province Name (full name) []:BeiJing Locality Name (eg, city) [Default City]:BeiJing Organization Name (eg, company) [Default Company Ltd]:Company Organizational Unit Name (eg, section) []:OPS Common Name (eg, your name or your server's hostname) []:www.test.com Email Address []: [root@centos7 ~]#
(1)所需目錄,若是無,則建立windows
/etc/pki/CA/certs/ /etc/pki/CA/crl/ /etc/pki/CA/newcerts/
(2)所需文件centos
[root@centos7 ~]# touch /etc/pki/CA/serial #序列號文件 [root@centos7 ~]# touch /etc/pki/CA/index.txt #數據庫文件
(3)瀏覽器
[root@centos7 ~]# echo 01 > /etc/pki/CA/serial #維護ca的序列號
(1)建立放置公鑰私鑰的文件夾ide
[root@CentOS7 ~]# mkdir /etc/httpd/ssl
(2)生成本身的私鑰測試
[root@CentOS7 ~]# (umask 077; openssl genrsa -out /etc/httpd/ssl/httpd.key 2048) Generating RSA private key, 2048 bit long modulus .......................................+++ ...................................+++ e is 65537 (0x10001) [root@CentOS7 ~]#
(3)請CA爲本身生成公鑰ui
[root@CentOS7 ~]# openssl req -new -key /etc/httpd/ssl/httpd.key -out /etc/httpd/ssl/httpd.csr -days 365 You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ----- Country Name (2 letter code) [XX]:CN State or Province Name (full name) []:BeiJing Locality Name (eg, city) [Default City]:BeiJing Organization Name (eg, company) [Default Company Ltd]:Company Organizational Unit Name (eg, section) []:OPS Common Name (eg, your name or your server's hostname) []:www.test.com Email Address []: Please enter the following 'extra' attributes to be sent with your certificate request A challenge password []: An optional company name []:
(4)把生成的公鑰發送給CAcentos7
[root@CentOS7 ~]# scp /etc/httpd/ssl/httpd.csr root@192.168.29.3:/tmp/ The authenticity of host '192.168.29.3 (192.168.29.3)' can't be established. ECDSA key fingerprint is f2:2e:89:a2:8d:22:22:9c:a9:f8:c9:19:18:d3:b6:c4. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '192.168.29.3' (ECDSA) to the list of known hosts. root@192.168.29.3's password: httpd.csr 100% 1005 1.0KB/s 00:00
[root@centos7 ~]# openssl ca -in /tmp/httpd.csr -out /etc/pki/CA/certs/httpd.crt -days 365 Using configuration from /etc/pki/tls/openssl.cnf Check that the request matches the signature Signature ok Certificate Details: Serial Number: 1 (0x1) Validity Not Before: Jun 3 02:54:23 2017 GMT Not After : Jun 3 02:54:23 2018 GMT Subject: countryName = CN stateOrProvinceName = BeiJing organizationName = Company organizationalUnitName = OPS commonName = www.test.com X509v3 extensions: X509v3 Basic Constraints: CA:FALSE Netscape Comment: OpenSSL Generated Certificate X509v3 Subject Key Identifier: 5D:A9:5A:90:29:F3:3A:7F:76:BE:21:78:14:80:E5:FB:5E:03:D8:D9 X509v3 Authority Key Identifier: keyid:9E:1E:F3:84:4D:D0:79:E2:BD:DD:A8:50:29:6C:BA:0C:21:60:CA:96 Certificate is to be certified until Jun 3 02:54:23 2018 GMT (365 days) Sign the certificate? [y/n]:y 1 out of 1 certificate requests certified, commit? [y/n]y Write out database with 1 new entries Data Base Updated
[root@centos7 ~]# scp /etc/pki/CA/certs/httpd.crt root@192.168.29.100:/etc/httpd/ssl/ The authenticity of host '192.168.29.100 (192.168.29.100)' can't be established. ECDSA key fingerprint is 32:16:f3:2d:78:65:9f:a0:31:6c:dc:b9:24:e7:5a:8f. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '192.168.29.100' (ECDSA) to the list of known hosts. root@192.168.29.100's password: httpd.crt 100% 5711 5.6KB/s 00:00
[root@CentOS7 ~]# yum install mod_ssl -y
DocumentRoot "/data/https" ServerName www.test.com:443 <Directory "data/https"> AllowOverride None Require all granted </Directory> SSLCertificateFile /etc/httpd/ssl/httpd.crt SSLCertificateKeyFile /etc/httpd/ssl/httpd.key
注意:code
並修該/etc/httpd/ssl/httpd.crt、/etc/httpd/ssl/httpd.key兩個文件的屬性,確保apach爲可讀就行,固然也可放在默認文件夾下,就不須要修改權限了。 [root@CentOS7 ~]#chmod +r /etc/httpd/ssl/httpd.key
[root@CentOS7 ~]# httpd -t Syntax OK
[root@CentOS7 ~]# echo "www.test.com" > /data/https/index.html
[root@CentOS7 ~]# systemctl start httpd.service
[root@centos7 ~]# sz /etc/pki/CA/cacert.pem
更名爲cacert.crt
雙擊導入IE瀏覽器
www.test.com 爲192.168.29.100
或者 修改windows 下的C:\Windows\Systeme32\drivers\etc\hosts文件
192.168.29.100 www.test.com
輸入https://www.test.com
好了 成功了 好用成就感呀!!