最近使用了acme.sh 生产了 Let's Encrypt 的https 证书,但是在实际服务器上测试遇到如下问题

  1. $ curl  "https://www.aaa.com"
  2.  
  3. 如下错误
  4. curl: (60) Peer's Certificate issuer is not recognized.
  5. More details here: http://curl.haxx.se/docs/sslcerts.html
  6.  
  7. curl performs SSL certificate verification by default, using a "bundle"
  8.  of Certificate Authority (CA) public keys (CA certs). If the default
  9.  bundle file isn't adequate, you can specify an alternate file
  10.  using the --cacert option


最开始我还以为是我服务器配置哪里出错了。后来测试了下其他国内的域名都可以访问,我就想到应该是https证书配置这块问题。后来查询了一些资料是我自己nginx 关于https配置不对导致的

  1. server {
  2.     listen 443 ssl;
  3.     ssl_certificate /home/www/.acme.sh/xxxxx/xxxx.cer;
  4.     ssl_certificate_key /home/www/.acme.sh/xxxxx/xxxx.key;
  5.     ssl_session_timeout 5m;
  6.     ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  7.     ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:DHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA;
  8.     ssl_session_cache shared:SSL:50m;
  9.  
  10. }
  11.  
  12. 其中 
  13. ssl_certificate /home/www/.acme.sh/xxxxx/xxxx.cer; 错误
  14. ssl_certificate /home/www/.acme.sh/xxxxx/fullchain.cer; 正确