基于UC实现在Liunx下进行Web服务器的搭建

基于UC实现在Liunx下进行Web服务器的搭建

在搭建简单的web服务器之前,我们要理清思路,分以下几步进行:

  • 安装基本环境,Liunx系统或者虚拟机
  • 了解超文本传输协议(HTTP)的传输机制
  • 服务器总体框架的构思
  • 根据框架程序的实现

1.环境搭建

第一步我就不多说了,现在网上都可以查到教程,而且还可以在win下安装虚拟机来进行安装Liunx。

2.超文本传输协议(HTTP)的传输机制。

由于我们实现的web服务器实现简单的htlm网页的访问,所以我们只需要了解HTTP协议头即可

1、同一局域网里,在打开浏览器后输入服务器IP,例如http://192.168.0.3:8888/Index.html,8888是我们自己设定的端口号。

此时浏览器会向服务器发送的HTTP协议头:

GET /Index.html HTTP/1.1
Host: 192.168.0.3:8888
Connection: keep-alive
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Encoding: gzip, deflate, sdch
Accept-Language: zh-CN,zh;q=0.8

其中第一行表示的是请求GET和协议的版本,我们实现的Web服务器只需要解析这一行就可以了

2、然后我们服务器需要作出解析应答:

  • 解析后服务器找到浏览器指定的文件
HTTP/1.1 200 OK //200表示找到浏览器请求的文件
Content-Type:text/html

<html>
<head>
<title>Test Page</title></head>
<body>
<h1>Test OK</h1>
<img src='mypic.jpg'>
</body>
</html>
  • 解析后未在指定路径找到文件,我们发送:
HTTP/1.1 400 Not Found 
Content-Type:text/html

<html>
<body>request file not found</body>
</html>

3、在浏览器收到Index.html文件后,发现其中有一个图片文件,那浏览器会再发一个GET请求:

GET /mypic.jpg HTTP/1.1
Host: 192.168.0.3:8888
Connection: keep-alive
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36
Accept: image/webp,image/*,*/*;q=0.8
Referer: http://192.168.0.3:8888/Index.html
Accept-Encoding: gzip, deflate, sdch
Accept-Language: zh-CN,zh;q=0.8
  • 同样服务器解析后,发送:
HTTP/1.1 200 OK 
Content-Type:image/jpg

(这里接的是mypic.jpg的二进制数据)

这样浏览器就应该可以显示整个网页。

3.服务器的整体框架构思

Created with Raphaël 2.1.0
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值