前言:
在之前,已经写过了很多服务器,如基于TCP和UDP的socket服务器,也知道了浏览一个百度首页的具体过程,现在,我们只要清楚HTTP协议,就可以构造一个HTTP请求,向服务器发送数据;也可以构造一个响应报文,就可以发送数据给客户端。还记得之前写过一个TFTP的客户端,我们只要构造一基于TFTP协议的数据报,就可以完成与服务器的交互。TFTP客户端链接:http://blog.csdn.net/keep_sweet/article/details/79365042。而现在,我们需要知道HTTP的数据格式是怎么样的。
一,客户端与服务器具体交互过程:
1.已经建立成功TCP三次握手,浏览器向服务器发送一个HTTP请求报文。
2.服务器接到空上报文后,返回一个响应报文。
3.如果还要继续访问,再次重复1,2步骤。
三,HTTP请求报文
1.方法:GET / HTTP/1.1 (get是一种请求类型,/是一个文件路径,它是指请求服务器中的哪个文件,HTTP/1.1是一个版本信息,不能少)
2.消息头(浏览的一些相关信息,如user-agent是浏览器的信息,这些在请求中自己可以定义)
3.消息体(可以放请求的数据)
四,响应报文
1.起始行(如HTTP/1.1 200 OK,其中200是状态码,OK是信息)
2.消息头
3.消息体(消息体中包括了显示页面的HTML文本等文件)
五,代码示例:
1. 服务器文件位置:
2.服务器代码
import socket
import re
from multiprocessing import Process
def response_info(conn, path):
HTML_ROOT_DIR = '.\html'
#找出文件在服务器中的位置
filename = HTML_ROOT_DIR + path
if '\\' == path:
filename = '.\html\index.html'
print(filename)
#若没有找到正确的文件,则报404 Not Found错误,找到了,则打开读取数据
try:
f = open(filename, 'rb')
response_body = f.read().decode()
except IOError:
response_start = 'HTTP/1.1 404 Not Found\r\n'
response_head = 'server:My server\r\n'
response_body = 'the file is exist\r\n'
else:
response_start = 'HTTP/1.1 200 OK\r\n'
response_head = 'server:My server\r\n'
finally:
info = response_start + response_head + '\r\n' + response_body
conn.send(info.encode('utf-8'))
conn.close()
def handle_request(conn):
'''处理客户端请求'''
recv_request = conn.recv(1024).decode()
#客户端请求数据行首
request_start = recv_request.splitlines()[0]
#由于windows中的文件目录为‘\’,所以要将其中'/'替换为'\'
path = request_start.split()[1]
new_path = re.sub('/', r'\\', path)
response_info(conn, new_path)
def main():
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
server.bind(('',8080))
server.listen(10)
while True:
#监听链接
conn,addr = server.accept()
p = Process(target=handle_request,args=(conn,))
p.start()
conn.close()
server.close()
if __name__ == '__main__':
main()3.浏览器打开,输入ip和port,返回结果
本文介绍了一个简单的HTTP服务器的实现过程,包括服务器与客户端之间的交互原理、HTTP请求与响应报文的构成,以及如何通过Python代码实现一个基本的HTTP服务器。
2179

被折叠的 条评论
为什么被折叠?



