如何在 Apache服务器上安装 SSL证书开启 https

目前网站 https越来越普及的今天,网站建设安装 ssl证书开启 https访问已经成为网站管理者的必须项目之一了。网上资料更多的是 nginx服务器的安装开启 https方法,而本文介绍的是如何在 Apache服务器上安装 SSL证书开启 https的方法过程。

Apache服务器上安装SSL

安装 SSL操作前提条件

  • 您的 Apache服务器上已经开启了443端口(HTTPS服务的默认端口)。
  • 您的 Apache服务器上已安装了mode_ssl.so模块(启用SSL功能)。
  • 本文档证书名称以domain name为示例,例如:证书文件名称为domain name_public.crt,证书链文件名称为domain name_chain.crt,证书密钥文件名称为domain name.key。
  • 申请证书时如果未选择系统自动创建CSR,证书下载压缩包中将不包含.key文件。

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

安装SSL具体操作步骤

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

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

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

3、在 Apache安装目录中新建 cert目录,并将解压的 Apache证书、证书链文件和密钥文件拷贝到 cert目录中。如果需要安装多个证书,需在 Apache目录中新建对应数量的 cert目录,用于存放不同的证书 。

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

4、修改 httpd.conf配置文件

在 Apache安装目录下,打开 Apache/conf/httpd.conf文件,并找到以下参数,按照下文中注释内容进行配置。

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

#Include conf/extra/httpd-ssl.conf #删除行首的配置语句注释符号“#”。

说明:如果您在 httpd.conf文件中没有找到以上配置语句,请确认您的 Apache服务器中是否已经安装 mod_ssl.so模块。可执行 yum install -y mod_ssl命令安装 mode_ssl模块。保存 httpd.conf文件并退出。

5、修改 httpd-ssl.conf配置文件

a.打开 Apache/conf/extra/httpd-ssl.conf文件并找到以下参数,按照下文中注释内容进行配置。

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

<VirtualHost *:443>

ServerName #修改为申请证书时绑定的域名www.YourDomainName1.com。

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替换成第二个域名。

ServerName #修改为申请证书时绑定的第二个域名www.YourDomainName2.com。

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替换成您申请证书时的第二个域名;证书链开头如果有#字符,请删除。

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

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

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

在 Apache的 bin目录下执行以下命令:

a.停止 Apache服务。

apachectl -k stop

b.开启 Apache服务。

apachectl -k start

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

在 httpd.conf文件中的 中间,添加以下重定向代码。

RewriteEngine on

RewriteCond %{SERVER_PORT} !^443$

RewriteRule ^(.*)$ https://%{SERVER_NAME}$1 [L,R]

收尾后续操作

证书安装完成后,您可通过登录证书的绑定域名验证该证书是否安装成功。

https://domain name #domain name替换成证书绑定的域名。​

如果网页地址栏出现小锁标志,表示证书安装成功。证书安装完成后,如果网站无法通过 https正常访问,需确认您安装证书的服务器 443端口是否已开启或被其他工具拦截。

 

转载请注明链接地址:荐爱小站 » 如何在 Apache服务器上安装 SSL证书开启 https

赞 (0) 赏 !

觉得文章有用就打赏一下吧,赠人玫瑰手有余香!

支付宝扫一扫打赏

微信扫一扫打赏