技术饭

Apache配置https启动不了的解决办法

copylian    0 评论    14494 浏览    2018.12.26

在证书控制台下载Apache版本证书,下载到本地的是一个压缩文件,解压后里面包含_public.crt文件是证书文件,_chain.crt是证书链(中间证书)文件,.key文件是证书的私钥文件(申请证书时如果没有选择系统创建CSR,则没有该文件)。

友情提示: .crt扩展名的证书文件采用Base64-encoded的PEM格式文本文件,可根据需要,修改成.pem等扩展名。

以Apache标准配置为例,假如证书文件名是a_public.crt,证书链文件是a_chain.crt,私钥文件是a.key。

操作步骤

1、在Apache的安装目录下创建cert目录,并且将下载的全部文件拷贝到cert目录中。如果申请证书时是自己创建的CSR文件,请将对应的私钥文件放到cert目录下并且命名为a.key;

2、打开 apache 安装目录下 conf 目录中的 httpd.conf 文件,找到以下内容并去掉“#”。


#LoadModule ssl_module modules/mod_ssl.so(如果找不到请确认是否编译过 openssl 插件)

#Include conf/extra/httpd-ssl.conf(删除行首的配置语句注释符号“#”,保存后退出)

3、打开 apache 安装目录下 conf/extra/httpd-ssl.conf 文件 (也可能是conf.d/ssl.conf,与操作系统及安装方式有关), 在配置文件中查找以下配置语句:


# 添加 SSL 协议支持协议,去掉不安全的协议

SSLProtocol all -SSLv2 -SSLv3

# 修改加密套件如下

SSLCipherSuite HIGH:!RC4:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!EXP:+MEDIUMSSLHonorCipherOrder on

# 证书公钥配置

SSLCertificateFile cert/a_public.crt

# 证书私钥配置

SSLCertificateKeyFile cert/a.key

# 证书链配置,如果该属性开头有 '#'字符,请删除掉

SSLCertificateChainFile cert/a_chain.crt

4、重启 Apache。

运行以下命令:/user/local/apache24/bin/apachectl restart

参考:https://help.aliyun.com/knowledge_detail/95493.html?spm=a2c4g.11186623.2.13.535534f1a0OocE

5、Apache配置https启动不了的解决办法

准备工作:有备案了的http域名,去阿里云或者腾讯云购买SSL证书,有免费1年的;

第一步;

找到 #LoadModule ssl_module modules/mod_ssl.so 和 #Include conf/extra/httpd-ssl.conf,去掉前面的#号注释;

第二步;

编辑Apache根目录下 conf/extra/httpd-ssl.conf 文件,修改如下内容:(路径一定要填对,不然启动不了)


Listen 443

<VirtualHost *:443>

        SSLEngine on


        # 添加 SSL 协议支持协议,去掉不安全的协议

        SSLProtocol all -SSLv2 -SSLv3


        # 修改加密套件如下

        SSLCipherSuite HIGH:!RC4:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!EXP:+MEDIUM

        SSLHonorCipherOrder on


        # 证书公钥配置

        SSLCertificateFile "/usr/local/apache24/cert/h5.ponyfamily.cn/1660533_h5.ponyfamily.cn_public.crt"


        # 证书私钥配置

        SSLCertificateKeyFile "/usr/local/apache24/cert/h5.ponyfamily.cn/1660533_h5.ponyfamily.cn.key"


        # 证书链配置,如果该属性开头有 '#'字符,请删除掉

        SSLCertificateChainFile "/usr/local/apache24/cert/h5.ponyfamily.cn/1660533_h5.ponyfamily.cn_chain.crt"


        DocumentRoot "/home/h5"

        ServerName abc.copylian.cn:443

        ServerAdmin copylian@aikehou.com

        ErrorLog "/usr/local/apache24/logs/abc.copylian.cn_log"

        TransferLog "/usr/local/apache24/logs/abc.copylian.cn_log"

        <Directory />

                Options +Indexes +FollowSymLinks +ExecCGI

                AllowOverride All

                Order allow,deny

                Allow from all

                Require all granted

        </Directory>

</VirtualHost>


如果还是启动不了,有80端口占用错误;删除conf文件夹的vhosts.conf文件的<VirtualHost _defate:80>

只袄早~~~
感谢你的支持,我会继续努力!
扫码打赏,感谢您的支持!
Apache https 

文明上网理性发言!

  • 还没有评论,沙发等你来抢