Windows环境下配置Apache 2.2.x + SSL ,实现https方式

本文主要内容来自 PCplayer整理的 windows安装基于Apache的SVN服务器(包括SSL配置) 他的这篇文章是我在配置Apache + ssl 的过程中找到的简明易懂最容易操作的教程. 因此摘抄一些过来, 分享给其它人. 在此感谢PCplayer的辛苦工作!
    本文所述在Windows 2003, Apache 2.2.6上面顺利设置成功.

----------
前提条件
----------
    在设置Apache + SSL之前, 需要做:
    1. 安装Apache, 请参见: Windows环境下Apache的安装与虚拟目录的配置, 下载安装Apache时请下载带有ssl版本的Apache安装程序.

    在进行下一步之前, 请确认Apache已经安装并可以正常工作. 并且ssl需要的文件在如下的位置:
    [Apache安装目录]/modules/ mod_ssl.so
    [Apache安装目录]/bin/ openssl.exe, libeay32.dll, ssleay32.dll
    [Apache安装目录]/conf/ openssl.cnf

----------
创建SSL证书
----------
    1. 打开cmd, cd到apache安装目录的bin目录
    2. 运行openssl

 

openssl req -config ..\conf\openssl.cnf -new -out my-server.csr 

 

(注意, my-server是自己起的名字, 以下步骤中提到my-server的也是自己起的名字) 这一步需要设置一系列的问题, 包括密码(这个密码要记住, 以后要用) 和其他的问题. 全部完成之后会生成一个my-server.csr和 privkey.pem 文件在bin文件夹中.

    3. 运行

 

openssl rsa -in privkey.pem -out my-server.key

 

此时要输入密码, 就是步骤2中设定的密码

    4. 运行

 

openssl x509 -in my-server.csr -out my-server.cert -req -signkey my-server.key -days 4000

 

这将创建一个4000天后才过期的证书

    5. 运行

 

openssl x509 -in my-server.cert -out my-server.der.crt -outform DER

 


    全部运行过后这些命令会在bin文件夹中生成6个文件:

 

.rnd
privkey.pem
my-server.der.crt
my-server.scr
my-server.key
my-server.cert

 


    将这些文件移到conf/ssl目录中(如果不存在这个目录就创建一个, 这个步骤中放到其他的目录也可以 关键是记住文件的位置, 在接下来的设置中会用到)

----------
设置Apache支持SSL
----------
注意: 本设置步骤针对针对Apache 2.2.x版本, 如果正在使用的是Apache 2.0.x版本, 请摸索相似的设置.

    在Apache的conf目录中用文本编辑器打开httpd.conf
    1. 去掉下面设置行前面的#

 

LoadModule ssl_module modules/mod_ssl.so

 

    2. 去掉下面设置行前面的# (在2.0.x版本中没有这一项)

 

Include conf/extra/httpd-ssl.conf

 


    3. 在Apache的conf/extra目录中打开httpd-ssl.conf, 更改如下设置. [apache安装目录]是指Apache的安装目录, 比如c:/Apache; my-server的两个文件就是前一个步骤制作的文件, 文件的位置就是这些文件在磁盘中的位置 (在2.0.x版本中这些设置仍然在 httpd.conf文件中进行)

 

SSLMutex  default
SSLCertificateFile "[Apache安装目录]/conf/ssl/my-server.der.crt"
SSLCertificateKeyFile "[Apache安装目录]/conf/ssl/my-server.key"

 


----------
测试
----------
    1. 保存设置文件
    2. 在开始菜单中运行Apache的Test Configuration工具, 检查设置文件是否正确
    3. 重新启动Apache 2.2.x,如果重启失败,查看http端口和https端口有没有被占
    4. 顺利启动之后, 在浏览器中输入 https://localhost  看看是否可以访问, 如果可以访问, 则设置成功!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值