更新时间:2024-03-21 GMT+08:00

在Apache服务器上安装私有证书

本文以CentOS 7操作系统中的Apache 2.4.6服务器为例介绍私有证书的安装步骤。

由于服务器系统版本或服务器环境配置不同,在安装私有证书过程中使用的命令或修改的配置文件信息可能会略有不同,云证书管理服务提供的安装证书示例,仅供参考,请以您的实际情况为准。

前提条件

  • 证书已签发。
  • 已下载Apache格式的私有证书,具体操作请参见下载证书
  • 申请证书时选择的“证书请求文件”生成方式为“系统生成文件”

约束条件

  • 证书安装前,务必在安装私有证书的服务器上开启“443”端口,同时在安全组增加“443”端口,避免安装后仍然无法启用HTTPS。
  • 为了使客户端信任服务器证书,需要将服务器证书的根CA加入到客户端受信任的根证书颁发机构中,详细操作请参见信任根CA
  • 如果一个域名有多个服务器,则每一个服务器上都要部署。
  • 待安装证书的服务器上需要运行的域名,必须与证书的域名一一对应,即申请的是哪个域名的证书,则用于哪个域名。否则安装部署后,浏览器将提示不安全。

操作步骤

在CentOS 7操作系统中的Apache 2.4.6服务器上安装私有证书的流程如下所示:

①获取文件②创建目录③修改配置文件④重启Apache⑤效果验证

步骤一:获取文件

在本地解压已下载的证书文件。

获得证书文件“ca.crt”“server.crt”和私钥文件“server.key”

  • “ca.crt”文件包括一段中级CA证书代码“-----BEGIN CERTIFICATE-----”“-----END CERTIFICATE-----”
  • “server.crt”文件包括一段服务器证书代码“-----BEGIN CERTIFICATE-----”“-----END CERTIFICATE-----”
  • “server.key”文件包括一段私钥代码“-----BEGIN RSA PRIVATE KEY-----”“-----END RSA PRIVATE KEY-----”

步骤二:创建目录

在Apache的安装目录下创建“cert”目录,并且将“server.key”“server.crt”“ca.crt”复制到“cert”目录下。

步骤三:修改配置文件

修改配置文件前,请将配置文件进行备份,并建议先在测试环境中进行部署,配置无误后,再在现网环境进行配置,避免出现配置错误导致服务不能正常启动等问题,影响您的业务。

  1. 打开Apache根目录下“conf.d/ssl.conf”文件。
  2. 配置证书绑定的域名。
    找到并修改如下参数:
    ServerName www.example.com:443 

    完整配置如下(以“www.domain.com”为例):

    ServerName www.domain.com:443 #用户服务器的域名
  3. 配置证书公钥。

    找到并修改如下参数:

    SSLCertificateFile "${SRVROOT}/conf/server.crt" 

    设置证书公钥文件“server.crt”文件的路径,例如“cert/server.crt”

    完整配置如下:

    SSLCertificateFile "cert/server.crt"
  4. 配置证书私钥。

    找到并修改如下参数:

    SSLCertificateKeyFile "${SRVROOT}/conf/server.key" 

    设置为“server.key”文件的路径,例如“cert/server.key”

    完整配置如下:

    SSLCertificateKeyFile "cert/server.key"
  5. 配置证书链。

    找到并修改如下参数:

    #SSLCertificateChainFile "${SRVROOT}/conf/server-ca.crt" 

    删除行首的配置语句注释符号“#”,并设置为“ca.crt”文件的路径,例如“cert/ca.crt”

    完整配置如下:

    SSLCertificateChainFile "cert/ca.crt"
  6. 修改后,保存“ssl.conf”文件并退出编辑。

步骤四:重启Apache

执行以下操作重启Apache,使配置生效。

  1. 执行service httpd stop命令停止Apache服务。
  2. 执行service httpd start命令启动Apache服务。

效果验证

部署成功后,可在浏览器的地址栏中输入“https://域名”,按“Enter”

如果浏览器地址栏显示安全锁标识,则说明证书安装成功。