一、Apache默认登录用户是daemon,如何修改登录用户?
data:image/s3,"s3://crabby-images/8bdb4/8bdb4358766698fb449e7333f1e29b9316ab4ca1" alt=""
新建一个用户Zhangsan和一个组httpd,修改httpd主配置文件。我是存放在/usr/local/apache2/conf/http.conf的。
data:image/s3,"s3://crabby-images/8f7d0/8f7d041c1663956af4a99e9e50c3c184ec01f669" alt=""
将User daemon改为User ZhangSan
Group daemon改为Group httpd
data:image/s3,"s3://crabby-images/ba773/ba773f92e8cb844ee386a5fff36afb386b6e241b" alt=""
重启httpd,查看进程用户
data:image/s3,"s3://crabby-images/450d9/450d9282fd47374078859267dde46d0f33c78560" alt=""
二、加密
为网站设置加密,需提供账号和密码才能访问
修改httpd主配置文件。
vim /usr/local/apache2/conf/http.conf
将AllowOverride none改为AllowOverride all
将Require all denied改为Require all granted
data:image/s3,"s3://crabby-images/b0e2d/b0e2df88038724e4c4fe62afb72c3e8f17db2f67" alt=""
data:image/s3,"s3://crabby-images/4a16f/4a16f1e08538a90b07d18d1b62eb22d842d12429" alt=""
然后在htdocs目录下新建隐藏配置文件.htaccess
cd /usr/local/apache2/htdocs
vim .htaccess //内容如下
data:image/s3,"s3://crabby-images/a7174/a7174bb77642a11564657f71577ccc0b7ae85072" alt=""
重启httpd,然后用htpasswd(可以先用whereis htpasswd查看一下命令所在目录,直接用绝对路径,这样不会出现命令找不到的问题)命令生成上图中的/usr/local/apache2/bin/a.psd文件
/usr/local/apache2/bin/apachectl restart //重启httpd
/usr/local/apache2/bin/htpasswd -c /usr/local/apache2/bin/a.psd web //生成web用户,并为其设置密码
进浏览器访问,发现是需要账号密码登录的了
如果想要去掉加密功能,可以直接将配置文件里的AllowOverride设为none
三、本机开启httpd服务后,局域网内其他用户不能访问网站
经查是防火墙的原因
重新设置防火墙
data:image/s3,"s3://crabby-images/a7d46/a7d46c6c34fe49a52b25d02c8f7054d1b69f6495" alt=""
data:image/s3,"s3://crabby-images/59317/59317f3053fa4774919b19a3033d4bc25690e6c8" alt=""
重启防火墙
data:image/s3,"s3://crabby-images/c0b39/c0b399caaff62b1669650b8b2ec15f217ddf600d" alt=""
成功
四、限制访问网站的客户机地址
修改主配置文件
将Require all granted修改为
<requireall>
Require all granted
require ip 192.168.252.128 //设置此网站只能被192.168.252.128访问,如果设置这个地址不能访问,则在前面加not
</requireall>
按照上面的设置后,我再用本机访问网站地址,被拒绝了,用搭建这个网站的虚拟机来访问是可以的。
data:image/s3,"s3://crabby-images/402ad/402add18de4b4a796f246ea0dc7f379101b5da7f" alt=""
data:image/s3,"s3://crabby-images/f061c/f061c29cc66d173019a803f602eeca129d9992ad" alt=""
五、首页文件缺失
首页文件在主配置文件的设置模块为
<IfModule dir_module>
DirectoryIndex index.html
</IfModule>
如果首页文件index.html被删除的话,访问网站会直接显示出网站上的其他文件,方便但是可能不太安全。
data:image/s3,"s3://crabby-images/017ea/017eaf8bcb6dd3ca1cfe264a5b7b015fde617ee9" alt=""
如果想要关闭这个功能,在首页文件缺失的时候不暴露内容,
用参数Options Index FollowSynlinks来控制,修改主配置文件。去掉Indexes参数
data:image/s3,"s3://crabby-images/91541/9154133ae09f7ae22c038983d39fe26f31b4f93f" alt=""
重新进网站,已经不会显示其他文件了。
data:image/s3,"s3://crabby-images/860bb/860bb8923a53a86a9e5453134dce8ba42b5896b3" alt=""
六、vhosts实现虚拟主机访问
vhosts功能开关在主配置文件中,所以先修改主配置文件,使得httpd-vhosts.conf文件生效,在httpd-vhosts.conf文件中配置虚拟机信息,然后配置主机的hosts,重启httpd,使配置生效。
data:image/s3,"s3://crabby-images/9f4cd/9f4cdf65e89c2bcb9aae26df2b85ce3027d521e6" alt=""
vim /usr/local/apache2/conf/httpd.conf //修改主配置文件
data:image/s3,"s3://crabby-images/1e61a/1e61a1d250651a2aadaddf9b3068a6c0b4248d1c" alt=""
vim /usr/local/apache2/conf/extra/httpd-vhosts.conf //配置虚拟主机信息
data:image/s3,"s3://crabby-images/2675e/2675ef0b4e44d6a96eea8a835d39be6050cb8519" alt=""
vim /etc/hosts //修改hosts
data:image/s3,"s3://crabby-images/986e4/986e47cdbfd4cac6af511952204fc3d3922a3041" alt=""
为两个虚拟主机添加首页文件。
data:image/s3,"s3://crabby-images/fc189/fc18987eadd92cc0d750a05e2900346248b8901e" alt=""
重启httpd服务后,成功
data:image/s3,"s3://crabby-images/c53b9/c53b966125e2abb93b74eab573fe0d143d58221d" alt=""
data:image/s3,"s3://crabby-images/fde14/fde14b1042c4d16bd1dbdb1e367de478c8c609b3" alt=""
七、本机可以访问虚拟主机域名,局域网内其他用户不可以
分析:
设定虚拟主机后,发现只能在本机输入域名访问才有效,在局域网内的其他用户都是无效的,仍然只能通过访问ip来进行。这个问题困扰了我好久,通过修改防火墙和vhosts配置问价多次仍不得要领。所以仔细把ip和域名的关系缕了一遍,终于给我找到了问题。因为我刚刚在本机上的hosts文件添加了ip和域名的对应关系,所以本机输入域名是可以找到ip,并进行解析的。但是在局域网内的其他主机上并没有这个对应关系,所以我在windows系统的hosts文件中增加了对应关系。windows系统的hosts文件存在这里:
data:image/s3,"s3://crabby-images/c4a0d/c4a0dd6ed166a36047615e9190dafe3d5ab29d0c" alt=""
data:image/s3,"s3://crabby-images/70b2f/70b2fba85c8ee5711faecbc17ecb642f9b60c508" alt=""
成功!
八、设置网页文件存放目录
Apache的网页文件存放目录默认为htdocs,在主配置文件中修改目录权限。
[root@www htdocs]# vim /usr/local/apache2/conf/httpd.conf
DocumentRoot "/usr/local/apache2/htdocs"
<Directory "/usr/local/apache2/htdocs">
Options Indexes FollowSymLinks //Options指令通知Apache禁止使用目录索引,FollowSymLinks表示不允许使用符号链接
AllowOverride None //禁止用户对目录配置文件(.htaccess)进行重载 (修改)
Order deny,allow //更改访问权限的优先顺序,禁止默认访问的存在
Allow from all
</Directory>
data:image/s3,"s3://crabby-images/a7213/a7213fe257dab48191b1d84666528413484a9964" alt=""
网友评论