在Apache服务器上安装SSL证书

SSL证书可免费申请,本文介绍了证书安装的具体操作。

前提条件

  • 已在数字证书管理服务控制台完成证书的签发和下载。具体操作,请参见下载证书到本地。
  • 您的Apache服务器上已经开启了443端口(HTTPS服务的默认端口)。
  • 您的Apache服务器上已安装了mod_ssl.so模块(启用SSL功能)

操作步骤

注意 本文档证书名称以domain_name为示例,例如:证书文件名称为domain_name_public.crt,证书链文件名称为domain_name_chain.crt,证书密钥文件名称为domain_name.key。

1.解压已下载保存到本地的Apache证书文件。

解压后的文件夹中有3个文件:

  • 证书文件:以.crt为后缀或文件类型。
  • 证书链文件:以.crt为后缀或文件类型。
  • 密钥文件:以.key为后缀或文件类型。

说明 申请证书时如果CSR生成方式选择的是手动填写或选择已有的CSR,未选择系统生成,则证书下载压缩包中将不包含.key文件(密钥文件)。
.crt扩展名的证书文件采用Base64-encoded的PEM格式文本文件,可根据需要修改成.pem等扩展名。关于证书格式转换的具体操作,请参见如何转换证书格式?。

2.在Apache安装目录中新建cert目录,并将解压的Apache证书、证书链文件和密钥文件拷贝到cert目录中。

如果需要安装多个证书,需在Apache安装目录中新建对应数量的cert目录,用于存放不同的证书 。

说明 如果申请证书时CSR生成方式选择了手动填写,请将手动生成创建的密钥文件拷贝到cert目录中并命名为domain_name.key

3.修改httpd.conf配置文件。

a.在Apache安装目录Apache/conf/下,打开httpd.conf文件。

说明 Apache/conf/为Apache的默认安装目录,如果修改过该路径,您需要在修改后的路径下查找httpd.conf文件。

b.在httpd.conf文件中找到以下参数,按照下文中注释内容进行配置。

#LoadModule ssl_module modules/mod_ssl.so  #删除行首的配置语句注释符号“#”加载mod_ssl.so模块启用SSL服务,Apache默认是不启用该模块的。
#Include conf/extra/httpd-ssl.conf  #删除行首的配置语句注释符号“#”。

c.保存httpd.conf文件并退出。

4.修改httpd-ssl.conf配置文件

a.在Apache/conf/extra/目录下,打开httpd-ssl.conf文件。

说明 根据操作系统的不同,http-ssl.conf文件也可能存放在conf.d/ssl.conf/目录下。

b.在httpd-ssl.conf文件中找到以下参数,按照下文中注释内容进行配置。

<VirtualHost *:443>     
    ServerName   #修改为申请证书时绑定的域名。                    
    DocumentRoot  /data/www/hbappserver/public          
    SSLEngine on   
    SSLProtocol all -SSLv2 -SSLv3 # 添加SSL协议支持协议,去掉不安全的协议。
    SSLCipherSuite HIGH:!RC4:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!EXP:+MEDIUM   # 修改加密套件。
    SSLHonorCipherOrder on
    SSLCertificateFile cert/domain_name1_public.crt   # 将domain_name1_public.crt替换成您证书文件名。
    SSLCertificateKeyFile cert/domain_name1.key   # 将domain_name1.key替换成您证书的密钥文件名。
    SSLCertificateChainFile cert/domain_name1_chain.crt  # 将domain_name1_chain.crt替换成您证书的密钥文件名;证书链开头如果有#字符,请删除。
</VirtualHost>

#如果证书包含多个域名,复制以上参数,并将ServerName修改为第二个域名。 
<VirtualHost *:443>     
    ServerName   #修改为申请证书时绑定的第二个域名。                    
    DocumentRoot  /data/www/hbappserver/public          
    SSLEngine on   
    SSLProtocol all -SSLv2 -SSLv3 # 添加SSL协议支持协议,去掉不安全的协议。
    SSLCipherSuite HIGH:!RC4:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!EXP:+MEDIUM   # 修改加密套件。
    SSLHonorCipherOrder on
    SSLCertificateFile cert/domain_name2_public.crt   # 将domain_name2替换成您申请证书时的第二个域名。
    SSLCertificateKeyFile cert/domain_name2.key   # 将domain_name2替换成您申请证书时的第二个域名。
    SSLCertificateChainFile cert/domain_name2_chain.crt  # 将domain_name2替换成您申请证书时的第二个域名;证书链开头如果有#字符,请删除。
</VirtualHost>

注意 请关注您的浏览器版本是否支持SNI功能。如果不支持,多域名证书配置将无法生效。

c.保存httpd-ssl.conf文件并退出。

5.可选:修改httpd.conf文件,设置HTTP请求自动跳转HTTPS。

在httpd.conf文件中的<VirtualHost *:80> </VirtualHost>中间,添加以下重定向代码。

RewriteEngine on
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^(.*)$ https://%{SERVER_NAME}$1 [L,R]

6.重启Apache服务器使SSL配置生效。

在Apache的bin目录下执行以下步骤:

a.执行apachectl -k stop停止Apache服务。

b.执行apachectl -k start开启Apache服务。

© 版权声明
THE END
喜欢就支持一下吧
点赞0赞赏 分享
评论 抢沙发
头像
拿起笔,写下你的梦想,你的人生就从此刻起航
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容