Apache是当今最为流行的web服务器,apache的站点安全可以通过身份验证、来源控制和加密访问来解决。首先我们安装一下http,至于rpm安装小编就不在这里多说了。下面给大家好好讲解一下httpd.conf这个文件里面的内容。我都给大家很好的注释在了上面,好好了解一下他们,很有助于我们来解决apache的站点安全。
data:image/s3,"s3://crabby-images/5fc28/5fc28832f94612097f555dbceeddfb0812a6f1ea" alt="apache站点安全 2-179.png"
data:image/s3,"s3://crabby-images/89e76/89e761bf61cf654fd0417bd95334d86015492f3e" alt="apache站点安全 2-181.png"
data:image/s3,"s3://crabby-images/e3715/e3715483fc588bc9b2d03eb5d70dca01561e6f33" alt="apache站点安全 2-183.png"
服务器监听端口: Listen 80 监听端口
data:image/s3,"s3://crabby-images/dea24/dea249336005d1a47c946b96f91ce9ef7cde54f5" alt="apache站点安全 2-211.png"
data:image/s3,"s3://crabby-images/439b1/439b1b19e061d927cdd5d1a75fb88ef2beb9ce02" alt="apache站点安全 2-213.png"
data:image/s3,"s3://crabby-images/b1493/b1493590bd282fd8cfe0c5ed5af85ac6c57d223e" alt="apache站点安全 2-215.png"
下面我们来看一下第一种站点安全的解决方法:
1.身份验证
在配置文件中修改 alloworverride all
data:image/s3,"s3://crabby-images/9388e/9388e29c5dba280db51acb3f9f5d8bad10b00409" alt="apache站点安全 2-320.png"
编辑一下说明文件 .htaccess
data:image/s3,"s3://crabby-images/6f811/6f811552de7234aa238edfe256561644d3d37411" alt="apache站点安全 2-414.png"
authuserfile /var/www/.htpasswd
authname "please input your name and password"
authtype basic
require valid-user
data:image/s3,"s3://crabby-images/99faf/99faf3b06df58b0db95be540bda06cb38bbd1fc2" alt="apache站点安全 2-672.png"
产生帐号文件
htpasswd -c 张号文件 帐号
data:image/s3,"s3://crabby-images/4c1c2/4c1c2da78d2fd931a57e7831b6975d85cf36caba" alt="apache站点安全 2-706.png"
data:image/s3,"s3://crabby-images/9f4a8/9f4a8e02ac90bbe56fea023ee9a138017c6f4e28" alt="apache站点安全 2-708.png"
下面我们来看看访问效果
data:image/s3,"s3://crabby-images/082ea/082ea7f3bde5ea6563531c208615438476c35476" alt="apache站点安全 2-722.png"
data:image/s3,"s3://crabby-images/43a50/43a50de20b8c9c8cf5a4e1a717f2cd8527e6f535" alt="apache站点安全 2-724.png"
data:image/s3,"s3://crabby-images/36efc/36efc50290958314c2d4b8b704769a25da38bb5c" alt="apache站点安全 2-726.png"
2.来源控制
在站点主目录中我们可以限制访问的ip地址来达到来源的控制,实现站点安全
Order allow,deny
deny from 192.168.2.100
allow from all
我们要注意的是Order allow,deny 中allow和deny的顺序,他们的顺序决定了是先执行的顺序。
data:image/s3,"s3://crabby-images/7c6bb/7c6bb0d048fa0a50aa7297ff2b7495545dc20ff5" alt="apache站点安全 2-911.png"
data:image/s3,"s3://crabby-images/80f29/80f29c6a531ec4d9f9b303c4dfc50dc6e65f131e" alt="apache站点安全 2-913.png"
data:image/s3,"s3://crabby-images/47c0f/47c0f56f6df44166837ea72c4f8bc89ff9707143" alt="apache站点安全 2-915.png"
data:image/s3,"s3://crabby-images/eb113/eb113a61dfaaeaeb943bc006e2c1e2d19da4c7c4" alt="apache站点安全 2-917.png"
3.加密访问
【原理】
HTTPS(全称:Hypertext Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,提供了身份验证与加密通讯方法,现在它被广泛用于万维网上安全敏感的通讯,例如交易支付方面。它的主要作用可以分为两种:一种是建立一个信息安全通道,来保证数据传输的安全;另一种就是确认网站的真实性。
【环境】
服务器Linux rhel5.4
客服端windows xp
安装的软件包httpd-2.2.3-31.el5.i386.rpm
mod_ssl-2.2.3-31.el5.i386.rpm
distcache-1.4.5-14.1.i386.rpm
【实验拓扑图】
data:image/s3,"s3://crabby-images/93958/93958e560f9bab5e08b92d512f7ae4afb3c3cd0e" alt="apache站点安全 2-1293.png"
【实现步骤】
首先检查是否安装openssl
data:image/s3,"s3://crabby-images/00acd/00acd95600ef72f638cbc2b62d8a8d3e8fe06f82" alt="apache站点安全 2-1346.png"
data:image/s3,"s3://crabby-images/6868a/6868ac13c9c7bdb16391cb5a426eb7b68fe7f822" alt="apache站点安全 2-1348.png"
data:image/s3,"s3://crabby-images/42a70/42a70be0b16c3dfcf82acc5acf27c8f89d94796b" alt="apache站点安全 2-1380.png"
实现摘要:
文件实现方法: openssl md5/sha 文件名
信息实现方法: echo “信息” |openssl md5/sha
data:image/s3,"s3://crabby-images/65274/652748a4c7af7cf6fa8da79463042f6a93f593dd" alt="apache站点安全 2-1494.png"
data:image/s3,"s3://crabby-images/38699/3869938a20b888c0d1aaa25092bc778f18a27a6a" alt="apache站点安全 2-1496.png"
data:image/s3,"s3://crabby-images/b61f2/b61f21943ebb0fe33bcbd40102d1771dd7a78d42" alt="apache站点安全 2-1498.png"
公钥私钥对的产生:
私钥的产生:openssl gensa 1024 产生一个1024位长度的私钥
openssl gensa 1024 >key.pem 产生到key.pem文件中去
私钥需要严格保管,需要修改权限:
chmod 600 key.pem
公钥可以在私钥中提取:
openssl rsa -in key.pem -pubout -out public.key
证书的实现步骤:
openssl genrsa 1024 >私钥文件
openssl req -new -key 私钥文件 -out 请求文件
openssl ca -in 请求文件 -out 证书
创建CAlinux CA 【openca】
简易的我们一般使用【openssl】
1.vim /etc/pki/tls/openssl.conf
data:image/s3,"s3://crabby-images/c62d1/c62d1f5d353b02e1daeabf6c7bf1c56c32a895e4" alt="apache站点安全 2-2095.png"
data:image/s3,"s3://crabby-images/1b7e5/1b7e54df0517eb23e5baec7f9e902d235d097839" alt="apache站点安全 2-2097.png"
data:image/s3,"s3://crabby-images/a5110/a51108b7dab735eb5a51f70c0bb8e1d97e0d0dc3" alt="apache站点安全 2-2099.png"
2.进入/etc/pki/CA创建文件夹和文件
mkdir certs newcerts crl
touch index.txt serial
data:image/s3,"s3://crabby-images/53383/533838174c57df1c6320838758a0b1776014a948" alt="apache站点安全 2-2220.png"
data:image/s3,"s3://crabby-images/73410/734102fafdf68cfb8e64a43ea7ec450ddf971cea" alt="apache站点安全 2-2222.png"
3.私钥过程:
创建私钥 openssl genrsa 1024 >private/cakey.pem
修改权限Chmod 600 private/*
data:image/s3,"s3://crabby-images/c70b0/c70b0e369481f7371935034eff89b2d4fe4dc4fc" alt="apache站点安全 2-2317.png"
给自己创建一个证书openssl req -new -key private/cakey.pem -x509 -out cacert.pem
data:image/s3,"s3://crabby-images/ff4d9/ff4d92764e77ddf9bfcc366df267fefe1621e8e1" alt="apache站点安全 2-2396.png"
web server
安装模块
data:image/s3,"s3://crabby-images/05fde/05fde85d44ef17bbaa4761278f12fef9c41bc61a" alt="apache站点安全 2-2414.png"
查看一下安装生成的文件
data:image/s3,"s3://crabby-images/009be/009be30cc0291838b462dc9660afcd85603974e1" alt="apache站点安全 2-2428.png"
创建目录
data:image/s3,"s3://crabby-images/2c399/2c399fb5a897c48d58facc723d61db2d5f96a604" alt="apache站点安全 2-2438.png"
产生私钥文件openssl genrsa 1024 >私钥文件
产生请求文件openssl req -new -key 私钥文件 -out 请求文件
data:image/s3,"s3://crabby-images/d3bcb/d3bcb8c5f611ace82c1b75176c6c1a84bbaad6eb" alt="apache站点安全 2-2537.png"
产生证书: openssl ca -in 请求文件 -out 证书
cd /etc/httpd/certs
data:image/s3,"s3://crabby-images/c057f/c057f6301b3254ad4e4b300f875bf214bd34fffc" alt="apache站点安全 2-2604.png"
捆绑 ssl.conf
Vim /etc/httpd/conf.d/ssl.conf
data:image/s3,"s3://crabby-images/07f1e/07f1ec0c9381008df4650164b29d16056b497491" alt="apache站点安全 2-2681.png"
接下来重启service httpd restart
查看一下端口是否打开
data:image/s3,"s3://crabby-images/c75a1/c75a10de951f9ef53c53399162ae26dd418acd4c" alt="apache站点安全 2-2722.png"
下面我们来看看访问效果
data:image/s3,"s3://crabby-images/a67c2/a67c203038abd1dbe686f35d1ba7491382f37470" alt="apache站点安全 2-2736.png"
我们可以看到浏览器呈现了证书
data:image/s3,"s3://crabby-images/2d9a6/2d9a6068a388dba5a5e9d45616a2f3060efadc1a" alt="apache站点安全 2-2753.png"
因为在客户端上没有证书,所以才会说不是由受信任的公司颁发
Vim /etc/httpd/conf.d/ssl.conf
data:image/s3,"s3://crabby-images/4eeaa/4eeaa4ffdc877b204589fa289d7ccf3c4ded2a00" alt="apache站点安全 2-2815.png"
data:image/s3,"s3://crabby-images/67cbc/67cbc49da925915ad3182a496f6882d34c430527" alt="apache站点安全 2-2817.png"
将证书安装一下,查看一下受信任的证书颁发机构
data:image/s3,"s3://crabby-images/a40b7/a40b7c9993fb080f6f24d9fbbf20ebcba9dc19be" alt="apache站点安全 2-2842.png"
再次访问一下
data:image/s3,"s3://crabby-images/ec4b8/ec4b8d26bf7a8ff39ca9551cf5524d826b24394c" alt="apache站点安全 2-2851.png"
发现名称无效或不匹配
我们需要在本机hosts文件中加入
192.168.2.100 www.abc.com
然后在/etc/httpd/conf/httpd.conf中禁用80端口再来访问
data:image/s3,"s3://crabby-images/99b99/99b997b3e9a30cc4c02c060f0db44b300ce0827d" alt="apache站点安全 2-2985.png"
本文出自 “木小浩-51CTO” 博客,请务必保留此出处http://muxiaohao.blog.51cto.com/7208070/1282980
(责任编辑:IT) |