Linux 自簽名 CA 本地主機 IP,安全 SSL 證書 for HTTPS
存放證書目錄
新建存放證書目錄,並進入:
mkdir certs
cd certs
成為證書頒發機構 CA
產生根私鑰:
openssl genrsa -des3 -out ftCA.key 2048
產生根簽名證書:
openssl req -x509 -new -nodes -key ftCA.key -sha256 -days 36500 -out ftCA.pem
產生 CA 簽名證書
產生私鑰:
penssl genrsa -out ft.com.key 2048
產生簽名證書請求:
openssl req -new -key ft.com.key -out ft.com.csr
產生擴展設定檔案:
IP.1 = 替換為您的本地主機 IP
vim ft.com.ext
authorityKeyIdentifier=keyid,issuer
basicConstraints=CA:FALSE
keyUsage = digitalSignature, nonRepudiation, keyEncipherment, dataEncipherment
subjectAltName = @alt_names
[alt_names]
DNS.1 = ft.com # Be sure to include the domain name here because Common Name is not so commonly honoured by itself
DNS.2 = bar.ft.com # Optionally, add additional domains (I've added a subdomain here)
IP.1 = 192.168.1.233 # Optionally, add an IP address (if the connection which you have planned requires it)
產生簽名證書:
openssl x509 -req -in ft.com.csr -CA ftCA.pem -CAkey ftCA.key -CAcreateserial -out ft.com.crt -days 36500 -sha256 -extfile ft.com.ext
移除私鑰密碼
須移除私鑰密碼,否則使用的伺服器,如網頁伺服器 Nginx,使用時則須輸入密碼,否則將無法使用。
變更檔案名稱:
mv ft.com.key ft.com.key.raw
去除私鑰密碼:
openssl rsa -in ft.com.key.raw -out ft.com.key
刪除變更的檔案:
rm ./ft.com.key.raw
如何使用憑證
Chrome 設定
匯入根簽名證書:
data:image/s3,"s3://crabby-images/8c936/8c9366c75feae94c53eca932aaf2977571a209a1" alt=""
data:image/s3,"s3://crabby-images/8a12a/8a12aa1754b7ca57c93820ed40061d366d22bf5e" alt=""
data:image/s3,"s3://crabby-images/5fc97/5fc97581610c360114e64a138fdd5a3f6dda8182" alt=""
data:image/s3,"s3://crabby-images/590b4/590b43395d2a90177dd4bc7096d75c178bb9024e" alt=""
data:image/s3,"s3://crabby-images/5fc28/5fc28bc8d71139807fac69d1fc494fff6be0c6ee" alt=""
data:image/s3,"s3://crabby-images/32907/32907756076743d22c0d90311f2a06e44ae0143f" alt=""
data:image/s3,"s3://crabby-images/20034/20034cfd59528b63686c56bd4b52159938f845a0" alt=""
data:image/s3,"s3://crabby-images/e02be/e02bece89bb22d637b593bbe72e77dd8f054a077" alt=""
data:image/s3,"s3://crabby-images/d3bb3/d3bb3970ecda1cd9fdecf97f0de3ea098b38d82e" alt=""
data:image/s3,"s3://crabby-images/95e57/95e5706963e294ff2e2cbe64c18d6c8bf1cab598" alt=""
伺服器使用
在伺服器使用這兩個檔案:
- ft.com.crt
- ft.com.key
參考
data:image/s3,"s3://crabby-images/96fb9/96fb900f8072af0831794f4b29bdc1e1d1c54198" alt="創用 CC 授權條款"
本著作係採用創用 CC 姓名標示-相同方式分享 3.0 台灣 授權條款授權.