自己做CA自签名证书生成

转载自:https://wangbin.io/blog/it/https-ca.html

自己做CA

最近chrome提示https证书错误,缺少subjectAltName,查了下解决方法,更新下。 

一. 简介

之前我的博客支持https使用的是向StartCom CA申请签发的一年免费证书。StartCom是受信赖的CA机构,它的根证书被各种操作系统和浏览器内置信任,所以由它签发的证书也会被信任。

最近做了个iOS ipa包上传下载程序,也需要使用https链接,上网查了下发现可以自己签名证书,所以实践了下,下面是详细步骤。

特别推荐下面这个网站,讲的是...非常详细。

OpenSSL Certificate Authority — Jamie Nguyen

教程里有些功能了解就可以了,我们不需要使用,所以我去掉了其中一些步骤,简单好用些。

二. CA

自己当CA,就是用openssl命令生成自己的根证书,让用户安装信任它,那么所有用这个根证书签名的证书,就也可以被信任啦。

所以做为CA,我们首先要生成自己的根证书ca.cert.pem,而生成根证书需要ca.key.pem。

开始

创建/root/ca文件夹,所有CA的操作都会在这个文件夹执行。

 
  1. # mkdir /root/ca

  2. # cd /root/ca

  3. # mkdir certs crl newcerts private

  4. # chmod 700 private

  5. # touch index.txt

  6. # echo 1000 > serial

  7. # touch openssl.cnf

/root/ca:CA文件夹

/root/ca/certs:新签署证书和根证书存放的位置

/root/ca/crl:证书请求文件存放位置

/root/ca/newcerts:新签署证书存放的位置,是/root/ca/certs的备份

/root/ca/private:ca.key.pem存放位置,千万别丢失

/root/ca/index.txt:证书签名的纪录

/root/ca/serial:下一次证书签名的序列号,保存到index.txt

拷贝下面内容到/root/ca/openssl.cnf

 
  1. # OpenSSL root CA configuration file.

  2. # Copy to `/root/ca/openssl.cnf`.

  3. [ ca ]

  4. # `man ca`

  5. default_ca = CA_default

  6. [ CA_default ]

  7. # Directory and file locations.

  8. dir = /root/ca

  9. certs = $dir/certs

  10. crl_dir = $dir/crl

  11. new_certs_dir = $dir/newcerts

  12. database = $dir/index.txt

  13. serial = $dir/serial

  14. RANDFILE = $dir/private/.rand

  15. # The root key and root certificate.

  16. private_key = $dir/private/ca.key.pem

  17. certificate = $dir/certs/ca.cert.pem

  18. # For certificate revocation lists.

  19. crlnumber = $dir/crlnumber

  20. crl = $dir/crl/ca.crl.pem

  21. crl_extensions = crl_ext

  22. default_crl_days = 30

  23. # SHA-1 is deprecated, so use SHA-2 instead.

  24. default_md = sha256

  25. name_opt = ca_default

  26. cert_opt = ca_default

  27. default_days = 3750

  28. preserve = no

  29. policy = policy_strict

  30. [ policy_strict ]

  31. # The root CA should only sign intermediate certificates that match.

  32. # See the POLICY FORMAT section of `man ca`.

  33. countryName = match

  34. stateOrProvinceName = match

  35. organizationName = match

  36. organizationalUnitName = optional

  37. commonName = supplied

  38. emailAddress = optional

  39. [ policy_loose ]

  40. # Allow the intermediate CA to sign a more diverse range of certificates.

  41. # See the POLICY FORMAT section of the `ca` man page.

  42. countryName = optional

  43. stateOrProvinceName = optional

  44. localityName = optional

  45. organizationName = optional

  46. organizationalUnitName = optional

  47. commonName = supplied

  48. emailAddress = optional

  49. [ req ]

  50. # Options for the `req` tool (`man req`).

  51. default_bits = 2048

  52. distinguished_name = req_distinguished_name

  53. string_mask = utf8only

  54. # SHA-1 is deprecated, so use SHA-2 instead.

  55. default_md = sha256

  56. # Extension to add when the -x509 option is used.

  57. x509_extensions = v3_ca

  58. [ req_distinguished_name ]

  59. # See <https://en.wikipedia.org/wiki/Certificate_signing_request>.

  60. countryName = Country Name (2 letter code)

  61. stateOrProvinceName = State or Province Name

  62. localityName = Locality Name

  63. 0.organizationName = Organization Name

  64. organizationalUnitName = Organizational Unit Name

  65. commonName = Common Name

  66. emailAddress = Email Address

  67. # Optionally, specify some defaults.

  68. countryName_default = CN

  69. stateOrProvinceName_default = JiangSu

  70. localityName_default = NanJing

  71. 0.organizationName_default = wangbin

  72. organizationalUnitName_default = wangbin

  73. emailAddress_default = webmaster@wangbin.io

  74. [ v3_ca ]

  75. # Extensions for a typical CA (`man x509v3_config`).

  76. subjectKeyIdentifier = hash

  77. authorityKeyIdentifier = keyid:always,issuer

  78. basicConstraints = critical, CA:true

  79. keyUsage = critical, digitalSignature, cRLSign, keyCertSign

  80. [ v3_intermediate_ca ]

  81. # Extensions for a typical intermediate CA (`man x509v3_config`).

  82. subjectKeyIdentifier = hash

  83. authorityKeyIdentifier = keyid:always,issuer

  84. basicConstraints = critical, CA:true, pathlen:0

  85. keyUsage = critical, digitalSignature, cRLSign, keyCertSign

  86. [ usr_cert ]

  87. # Extensions for client certificates (`man x509v3_config`).

  88. basicConstraints = CA:FALSE

  89. nsCertType = client, email

  90. nsComment = "OpenSSL Generated Client Certificate"

  91. subjectKeyIdentifier = hash

  92. authorityKeyIdentifier = keyid,issuer

  93. keyUsage = critical, nonRepudiation, digitalSignature, keyEncipherment

  94. extendedKeyUsage = clientAuth, emailProtection

  95. [ server_cert ]

  96. # Extensions for server certificates (`man x509v3_config`).

  97. basicConstraints = CA:FALSE

  98. nsCertType = server

  99. nsComment = "OpenSSL Generated Server Certificate"

  100. subjectKeyIdentifier = hash

  101. authorityKeyIdentifier = keyid,issuer:always

  102. keyUsage = critical, digitalSignature, keyEncipherment

  103. extendedKeyUsage = serverAuth

  104. subjectAltName = @alt_names

  105. [alt_names]

  106. IP.1 = 127.0.0.1

  107. IP.2 = 192.168.1.1

  108. DNS.1 = wangbin.io

  109. DNS.2 = ioptimi.wangbin.io

  110. [ crl_ext ]

  111. # Extension for CRLs (`man x509v3_config`).

  112. authorityKeyIdentifier=keyid:always

  113. [ ocsp ]

  114. # Extension for OCSP signing certificates (`man ocsp`).

  115. basicConstraints = CA:FALSE

  116. subjectKeyIdentifier = hash

  117. authorityKeyIdentifier = keyid,issuer

  118. keyUsage = critical, digitalSignature

  119. extendedKeyUsage = critical, OCSPSigning

具体的解释可以看上面的链接(真的是很推荐),这里我拣重要的说下

dir = /root/ca:这里需要改为上面的CA文件夹

policy = policy_strict:签CA证书使用strict策略

countryName_default = CN

0.organizationName_default = wangbin CA

这两个是国家和组织名字,会显示到生成的证书上。简单的签个CA证书,我们只设置这两个值,其他都是空。

[ v3_ca ]:签CA证书需要这个配置

[ server_cert ]:接下来签服务端证书需要这个

生成root key

 
  1. # cd /root/ca

  2. # openssl genrsa -aes256 -out private/ca.key.pem 4096

  3. 输入两次密码wangbin123456,这个是很重要的密码,设置严格点。

  4. # chmod 400 private/ca.key.pem

生成root certificate

 
  1. # cd /root/ca

  2. # openssl req -config openssl.cnf \

  3. -key private/ca.key.pem \

  4. -new -x509 -days 7500 -sha256 -extensions v3_ca \

  5. -out certs/ca.cert.pem

  6. 根据提示输入key的密码:wangbin123456

  7. 然后一值回车下去,使用默认值

  8. # chmod 444 certs/ca.cert.pem

-days 7300:有效期20年

到这一步ca.key.pem(root key)和ca.cert.pem(root certificate)都已经生成好了,路径如下

 
  1. /root/ca/private/ca.key.pem

  2. /root/ca/certs/ca.cert.pem

至此生成根证书完成。

ca.key.pem密码是wangbin123456,非常重要,需要好好保存。

ca.cert.pem就是根证书,需要把它发给用户,让用户安装信任它,这样以后我们用这个证书签名的证书就都可以被信任了。

三. 生成服务端证书

CA角色要做的工作已经完成了,下面我们以用户这个角色,生成一个tomcat和nginx可以使用的服务端证书。

这里假设我们网站的域名或ip地址是127.0.0.1,那么在ca同级目录下创建127.0.0.1文件夹,生成服务端证书操作都在这个目录下进行。

 
  1. # mkdir /root/127.0.0.1

  2. # cd /root/127.0.0.1

  3. # openssl genrsa -out server.key 2048

  4. # openssl req -new -key server.key -out server.csr

  5. 会出现提示,尽量全部都填写,防止以后浏览器对证书验证变得严格,又要重新签名。关键数据重复填写就可以了。

  6. Country Name输入:CN

  7. State or Province Name输入:JiangSu

  8. Locality Name(eg, city)输入:NanJing

  9. Organization Name (eg, company)输入:wangbin.io

  10. Organizational Unit Name (eg, section)输入:wangbin.io

  11. Common Name输入域名或ip:127.0.0.1

  12. Email Address:xxx@qq.com

  13. extra信息

  14. A challenge password输入:server123456

  15. An optional company name []:wangbin.io

openssl genrsa -out server.key 2048:这个命令后面2048代表加密位数,严格的使用4096,例如上面的根证书使用的就是这个,一般使用2048和1024就可以了,数值越大https链接等待时间越长。

到这儿,我们服务端key(server.key)和证书请求(server.csr)就生成啦。

接下来拷贝server.csr到ca/crl并改名为127.0.0.1.csr.pem

cp server.csr ../ca/crl/127.0.0.1.csr.pem

然后角色切换到CA角色,对这个请求进行处理。

首先修改下/root/ca/openssl.cnf

 
  1. policy = policy_strict

  2. 改为

  3. policy = policy_loose

policy_strict只在生成根证书的时候使用,其他时候使用loose策略就可以啦。

2017.08.31修改:将下面IP或者DNS更新为要签名的

 
  1. [alt_names]

  2. IP.1 = 127.0.0.1

  3. IP.2 = 192.168.1.1

  4. DNS.1 = wangbin.io

  5. DNS.2 = ioptimi.wangbin.io

执行命令,生成证书

 
  1. # cd /root/ca

  2. # openssl ca -config openssl.cnf \

  3. -extensions server_cert -days 375 -notext -md sha256 \

  4. -in crl/127.0.0.1.csr.pem \

  5. -out certs/127.0.0.1.cert.pem

-days 375:有效期375天,默认值也是375天

这时候,你会发现

  • /root/ca/certs下多了127.0.0.1.cert.pem(这个就是生成好的证书)
  • newcerts下面多了1000.pem(这个是证书备份,1000是从serial中取的)
  • /root/ca/index.txt多了行纪录

     
    1. /root/ca/index.txt

    2. V 171014020124Z 1000 unknown /C=CN/ST=Some-State/O=Internet Widgits Pty Ltd/CN=127.0.0.1

  • /root/ca/serial中的值+1变成了1001。

将/root/ca/certs/127.0.0.1.cert.pem证书发给用户,CA角色的工作就完成啦。

角色切换回用户,我们将CA发给我们的127.0.0.1.cert.pem拷贝到/root/127.0.0.1目录下,并改名为server.crt

cp certs/127.0.0.1.cert.pem ../127.0.0.1/server.crt

这时我们目录下有下面三个文件

server.crt server.csr server.key

server.crt就是我们要的证书,我们可以配置nginx支持https啦。

nginx配置

 
  1. server {

  2. listen 443;

  3. server_name 127.0.0.1;

  4. ssl on;

  5. ssl_certificate /root/127.0.0.1/server.crt;

  6. ssl_certificate_key /root/127.0.0.1/server.key;

  7. ssl_session_cache shared:SSL:1m;

  8. ssl_session_timeout 10m;

  9. ssl_ciphers HIGH:!aNULL:!MD5;

  10. ssl_prefer_server_ciphers on;

  11. location / {

  12. proxy_pass http://127.0.0.1;

  13. }

  14. location ~ ^(.*)\/\.svn\/ {

  15. deny all;

  16. }

  17. }

要支持tomcat的话,我们还需要进行下面的操作。

 
  1. # cd /root/127.0.0.1

  2. # openssl pkcs12 -export \

  3. -in server.crt \

  4. -inkey server.key \

  5. -out server.p12

  6. 输入两次密码:server123456

  7. # keytool -importkeystore -v \

  8. -srckeystore server.p12 \

  9. -srcstoretype pkcs12 \

  10. -srcstorepass server123456 \

  11. -destkeystore server.keystore \

  12. -deststoretype jks \

  13. -deststorepass server123456

操作后的文件目录

 
  1. server.crt server.csr server.key

  2. server.p12 server.keystore

tomcat配置

 
  1. <Connector SSLEnabled="true" clientAuth="false"

  2. keystoreFile="/root/127.0.0.1/server.keystore"

  3. keystorePass="server123456"

  4. maxThreads="150" port="8443" protocol="org.apache.coyote.http11.Http11Protocol" scheme="https" secure="true" sslProtocol="TLS"/>

结尾

以后如果需要生成别的服务端证书,我们就只用从三. 生成服务端证书开始就可以啦,是不是很easy.

最后

安装信任下我的根证书吧

点击下载

参考:

  1. OpenSSL Certificate Authority — Jamie Nguyen

  2. 使用itms-services安装ipa_RazerTang的专栏-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值