A-A+

Linux下让Apache支持SSL

2012年03月14日 Ssl 暂无评论 阅读 316 次浏览 次

我知道实在有太多的文章在介绍这个题目,我也参考过不少的文章, 但发现还是有不少的出入,经常会有一些小问题导致在编译、配置过程无法正常执行,现将我的配置过程写出来,使得在以后的配置过程中少走弯路。

软件环境(全部采用最新的版本):

RedHat AS3.0 (http://www.redhat.com)

Apache Httpd 2.0.53 (http://httpd.apache.org)

OpenSSL 0.9.7e (http://www.openssl.org/source)

SSL-Tools (http://www.openssl.org/contrib/ssl.ca-0.1.tar.gz)

安装步骤(所有操作使用root用户进行):

1. OpenSSL

#tar zxvf openssl-0.9.7e.tar.gz

#cd openssl-0.9.7e

#./config

#make

#make install

此举将安装最新的OpenSSL到/usr/local/ssl目录中,无需理会系统中已有版本的OpenSSL,也不要去卸载它,否则会导致很多 的应用程序无法正常执行,例如X窗口无法进入等错误。

2. Apache Httpd

#tar zxvf httpd-2.0.53.tar.gz 

#./configure --prefix=/apache/httpd --enable-ssl=static --with-ssl=/usr/local/ssl

#make 

#make install

此步骤在/apache/httpd目录中安装httpd服务(通过参数--prefix指定),同时使用--with-ssl指定刚才所安装 OpenSSL的路径,用于将mod_ssl静态的编译到httpd服务中。

3.制作证书

我们必须手工来生成SSL用到的证书,对证书不熟悉的人,有一个工具可以使用:http://www.openssl.org/contrib/ssl.ca-0.1.tar.gz 。 下面是如何通过这个工具来生成证书的过程:

#cp ssl.ca-0.1.tar.gz /apache/httpd/conf

#cd /usr/local/apache2/conf

#tar zxvf ssl.ca-0.1.tar.gz

#cd ssl.ca-0.1

#./new-root-ca.sh (生成根证书)

No Root CA key round. Generating one

Generating RSA private key, 1024 bit long modulus

...........................++++++

....++++++

e is 65537 (0x10001)

Enter pass phrase for ca.key: (输入一个密码)

Verifying - Enter pass phrase for ca.key: (再输入一次密码)

......

Self-sign the root CA... (签署根证书)

Enter pass phrase for ca.key: (输入刚刚设置的密码)

........

........ (下面开始签署)

Country Name (2 letter code) [MY]:CN

State or Province Name (full name) [Perak]:GuangDong//随你喜欢

Locality Name (eg, city) [Sitiawan]:GuangZhou//随你喜欢

Organization Name (eg, company) [My Directory Sdn Bhd]:GDLC//随你喜欢

Organizational Unit Name (eg, section) [Certification Services Division]:GDLC//随你喜欢

Common Name (eg, MD Root CA) []:winson CA//随你喜欢

Email Address []:yu.hanhui@gd-linux.org//随你喜欢

这 样就生成了ca.key和ca.crt两个文件,下面还要为我们的服务器生成一个证书:

# ./new-server-cert.sh server (这个证书的名字是server)

......

......

Country Name (2 letter code) [MY]:CN

State or Province Name (full name) [Perak]: GuangDong

Locality Name (eg, city) [Sitiawan]: GuangZhou

Organization Name (eg, company) [My Directory Sdn Bhd]:GDLC

Organizational Unit Name (eg, section) [Secure Web Server]:GDLC

Common Name (eg, www.domain.com) []:localhost

Email Address []:yu.hanhui@gd-linux.org

这样就生成了server.csr和server.key这两个文件。

还 需要签署一下才能使用的:

# ./sign-server-cert.sh server

CA signing: server.csr -> server.crt:

Using configuration from ca.config

Enter pass phrase for ./ca.key: (输入上面设置的根证书密码)

Check that the request matches the signature

Signature ok

The Subject's Distinguished Name is as follows

countryName :PRINTABLE:'CN'

stateOrProvinceName :PRINTABLE:'JiangSu'

localityName :PRINTABLE:'NanJing'

organizationName :PRINTABLE:'Wiscom System Co.,Ltd'

organizationalUnitName:PRINTABLE:'ACSTAR'

commonName :PRINTABLE:'acmail.wiscom.com.cn'

emailAddress :IA5STRING:'acmail@wiscom.com.cn'

Certificate is to be certified until Jul 16 12:55:34 2005 GMT (365 days)

Sign the certificate? [y/n]:y

1 out of 1 certificate requests certified, commit? [y/n]y

Write out database with 1 new entries

Data Base Updated

CA verifying: server.crt <-> CA cert

server.crt: OK



下面要按照ssl.conf里面的设 置,将证书放在适当的位置。

# chmod 400 server.key

# cd ..

# mkdir ssl.key

# mv ssl.ca-0.1/server.key ssl.key

# mkdir ssl.crt

# mv ssl.ca-0.1/server.crt ssl.crt

然后就可以启动啦!

# cd /usr/local/apache2

# ./bin/apachectl startssl

4. 测试HTTP服务

使用浏览器打开地址:https://127.0.0.1  完毕!!

整个配置过程是参照 http://www.gd-linux.org/bbs/archive/index.php/t-39.html 而 来的,我根据在实际的配置过程中碰到的问题做了一些改动,非常感谢这个作者的文章。

另外如果是Apache + Tomcat的配置环境,如果二者运行在同一台机器上或者是在安全的局域网内,则无需在Tomcat端再行配置SSL了,直接使用Apache Httpd的SSL即可,否则需要给Tomcat包括Jk另行配置SSL,相应的文章可以在网上搜索到。

 

评论已关闭!

Copyright © 香港虚拟主机_美国虚拟主机_香港服务器_美国服务器租用托管 保留所有权利.   Theme  Ality 蜀ICP备14006632号-1

用户登录