Web服务器实战

网站需求

1.基于域名www.openlab.com可以访问网站内容为 welcome to openlab!!!

2.给该公司创建三个网站目录分别显示学生信息,教学资料和缴费网站,基于www.openlab.com/student 网站访问学生信息,www.openlab.com/data网站访问教学资料

www.openlab.com/money网站访问缴费网站。

3.要求:

(1)学生信息网站只有song和tian两人可以访问,其他网站所有用户用能访问。

(2)访问缴费网站实现数据加密基于https访问。

准备

1.需要两台Linux虚拟机,一台为服务端server,另一台为客户端client

server IPV4:192.168.110.136/24 client IPV4:192.168.110.134/24

2.服务端需要关闭防火墙和Linux的安全服务seLinux

root@server \~\]# systemctl stop firewalld \[root@server \~\]# setenforce 0 \[root@server \~\]# getenforce Permissive 3.安装httpd,mol_ssl \[root@server \~\]# yum install -y httpd mod_ssl

配置

1.客户端通过IP地址可以正常访问服务端内容

root@server \~\]# mkdir -v /openlab/ #创建目录 已创建目录 '/openlab/' \[root@server \~\]# echo "welcome to openlab!!!" \> /openlab/index.html #写入内容 \[root@server \~\]# vim /etc/httpd/conf.d/openlab.conf #打开httpd的额外参数配置文件 \ Options Indexes FollowSymLinks AllowOverride None Require all granted \ \ ServerAdmin [email protected] DocumentRoot "/openlab/" ServerName www.openlab.com \ \[root@server \~\]# httpd -t #语法检测 Syntax OK \[root@server \~\]# systemctl restart httpd #重启服务 客户端访问 \[root@client \~\]# curl 192.168.110.136 welcome to openlab!!! ![](https://file.jishuzhan.net/article/1722566353849683970/8212dc5f4dd4f7620509575a06117311.webp) ![](https://file.jishuzhan.net/article/1722566353849683970/0a57901c6e3241e81b80b454c1815d86.webp)

2.搭建学生信息,教学资料,缴费网站页面

root@server \~\]# mkdir /openlab/{student,data,money} -v mkdir: 已创建目录 '/openlab/student' mkdir: 已创建目录 '/openlab/data' mkdir: 已创建目录 '/openlab/money' \[root@server \~\]# echo "学生信息" \> /openlab/student/index.html #写入内容 \[root@server \~\]# echo "教育网站" \> /openlab/data/index.html #写入内容 \[root@server \~\]# echo "缴费网站" \> /openlab/money/index.html #写入内容 首先配置student页面只有song和tian用户访问 \[root@server \~\]# htpasswd -c /etc/httpd/conf.d/httpd song #创建sond的身份验证文件 New password: Re-type new password: Adding password for user song \[root@server \~\]# htpasswd /etc/httpd/conf.d/httpd tian #添加tain的身份验证文件 New password: Re-type new password: Adding password for user tian \[root@server \~\]# cat /etc/httpd/conf.d/httpd song:$apr1$XWPO6i0/$hNsM5W/Gx3ukFsPokAEEH. tian:$apr1$SSblX1SO$YGyWDIuzZmCuLfhBnqn6m1 \[root@server \~\]# vim /etc/httpd/conf.d/openlab.conf #在额外参数配置文件添加内容 \ ServerAdmin [email protected] DocumentRoot "/openlab/student" ServerName www.openlab.com \ \ Options Indexes FollowSymLinks AllowOverride None AuthType Basic AuthName "Restricted Files" AuthUserFile "/etc/httpd/conf.d/httpd " #身份验证文件的路径 Require user song tian #允许访问的用户 \ \[root@server \~\]# httpd -t #语法检测 Syntax OK \[root@server \~\]# systemctl restart httpd #重启服务 客户端访问 \[root@client \~\]# curl 192.168.110.136/student/ -u song Enter host password for user 'song': 学生信息 \[root@client \~\]# curl 192.168.110.136/student/ -u tian Enter host password for user 'tian': 学生信息 ![](https://file.jishuzhan.net/article/1722566353849683970/1befe30d14a266fadc29a4236f6c903f.webp) 其他用户访问 ![](https://file.jishuzhan.net/article/1722566353849683970/440ed50a8eb03f5c9da8f8bdf91b9eb1.webp) ![](https://file.jishuzhan.net/article/1722566353849683970/b30d0603cb1dc73a63312f89cc1f4275.webp) ![](https://file.jishuzhan.net/article/1722566353849683970/a3665429e6e72444b0885400b8782316.webp) 配置教学资料网站所有用户都可访问 \[root@server \~\]# vim /etc/httpd/conf.d/openlab.conf #打开配置文件添加内容 \ Options Indexes FollowSymLinks AllowOverride None Require all granted \ \ ServerAdmin [email protected] DocumentRoot "/openlab/data/" ServerName www.openlab.com \ \[root@server \~\]# httpd -t Syntax OK \[root@server \~\]# systemctl restart httpd 客户端访问 \[root@client \~\]# curl 192.168.110.136/data/ 教育网站 ![](https://file.jishuzhan.net/article/1722566353849683970/13356cffd559ae724bd5edd85b1e31da.webp) ![](https://file.jishuzhan.net/article/1722566353849683970/ca634d77297a6541735a58e2630ad4f2.webp) 配置缴费网站实现数据加密基于https访问 \[root@server \~\]# cd /etc/pki/tls/certs/ #存放着一些证书文件 \[root@server certs\]# openssl genrsa 2048 \>\> openlab.key #生成私钥文件 \[root@server certs\]# openssl req -utf8 -new -key openlab.key -x509 -days 100 -out openlab.crt #生成证书 You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ----- Country Name (2 letter code) \[XX\]:SN #国家 State or Province Name (full name) \[\]:CN #省份 Locality Name (eg, city) \[Default City\]:XI'AN #城市 Organization Name (eg, company) \[Default Company Ltd\]:OPENLAB #企业 Organizational Unit Name (eg, section) \[\]:RHCE #部门 Common Name (eg, your name or your server's hostname) \[\]:www.openlab.com 域名 Email Address \[\]:[email protected] #邮件 \[root@server \~\]# vim /etc/httpd/conf.d/openlab.conf \ DocumentRoot "/openlab/money/" ServerName www.openlab.com SSLEngine on SSLCertificateFile "/etc/pki/tls/certs/openlab.crt" SSLCertificateKeyFile "/etc/pki/tls/certs/openlab.key" \ \ Options Indexes FollowSymLinks AllowOverride None Require all granted \ \[root@server \~\]# httpd -t Syntax OK \[root@server \~\]# systemctl restart httpd 客户端访问 \[root@client \~\]# curl https://192.168.110.136 -k #-k为忽略证书访问 缴费网站 \[root@client \~\]# curl 192.168.110.136/money/ -k 缴费网站 ![](https://file.jishuzhan.net/article/1722566353849683970/293e17e1aef64113bedf191e0957ad98.webp) ![](https://file.jishuzhan.net/article/1722566353849683970/323ff3f0a3f98e2890c269d7b0b1ff3e.webp)![](https://file.jishuzhan.net/article/1722566353849683970/123feaee1c488c6f6ab2855c562fb522.webp) /etc/httpd/conf.d/openlab.conf配置文件最终内容 ![](https://file.jishuzhan.net/article/1722566353849683970/cd786d4c99e93a9e415fd829ec0fd319.webp)

3.客户端通过域名可以正常访问服务端内容

在没有DNS域名解析服务器的情况下可以使用本机hosts文件,hosts文件其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联"数据库"

在Linux下hosts文件地址为/etc/host

root@client \~\]# vim /etc/hosts #写入内容 192.168.110.136 www.openlab.com \[root@client \~\]# curl www.openlab.com welcome to openlab!!! \[root@client \~\]# curl www.openlab.com/student/ -u song Enter host password for user 'song': 学生信息 \[root@client \~\]# curl www.openlab.com/student/ -u tian Enter host password for user 'tian': 学生信息 \[root@client \~\]# curl www.openlab.com/data/ 教育网站 \[root@client \~\]# curl https://www.openlab.com -k 缴费网站 \[root@client \~\]# curl www.openlab.com/money/ -k 缴费网站 ![](https://file.jishuzhan.net/article/1722566353849683970/a9e3efbd885c556ce263271c7d741517.webp) 在Windows客户端下hosts文件路径为C:\\Windows\\System32\\drivers\\etc\\hosts ![](https://file.jishuzhan.net/article/1722566353849683970/fc57035fde7ef1a760fc7dfbfc45fdf7.webp) 添加内容,浏览器访问即可

相关推荐
Johny_Zhao12 分钟前
CentOS Stream 10安装部署Zabbix 7.0网络监控平台和设备配置添加
linux·网络·网络安全·docker·信息安全·云计算·apache·zabbix·devops·yum源·huawei·系统运维·itsm·华三
zly886537213 分钟前
MLX5 Linux 驱动代码分析
linux·运维·fpga开发
进取星辰13 分钟前
28、动画魔法圣典:Framer Motion 时空奥义全解——React 19 交互动效
前端·react.js·交互
小oo呆15 分钟前
【学习心得】WSL2安装Ubuntu22.04
linux
国科安芯19 分钟前
高精度降压稳压技术在现代工业自动化中的应用
运维·自动化
code monkey.28 分钟前
【寻找Linux的奥秘】第五章:认识进程
linux·运维·硬件
愚润求学29 分钟前
【Linux】动静态库的使用
linux·运维·服务器·开发语言·c++·笔记
三天不学习30 分钟前
Vue3 本地环境 Vite 与生产环境 Nginx 反向代理配置方法汇总【反向代理篇】
运维·nginx·vue3·vite·反向代理
云途行者31 分钟前
windows、Ubuntu、Debian 添加静态路由
linux·windows·ubuntu
不爱吃饭爱吃菜1 小时前
uniapp微信小程序-长按按钮百度语音识别回显文字
前端·javascript·vue.js·百度·微信小程序·uni-app·语音识别