Flask或者其他框架都是封装的比较完善,我们可以不去关注路由、SESSION等到底是怎么实现的,现在我们使用socket来实现一个带有注册、登录功能的To do网站,这样能对后端框架了解的稍微更深入一点(当然你也可以直接去看Flask源码)。
主程序runserver.py代码如下:
#!/usr/bin/env python # -*- coding:utf-8 -*- import socket from exts import Request from route import response_for_request from datetime import datetime def run_server(host='', port=1207): # 建立一个socket.socket()类s with socket.socket() as s: # 设置s在服务端关闭后马上释放端口,避免Address already in use错误 s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # 绑定host和port s.bind((host, port)) while 1: # 开始监听传入连接,可以挂起的最大连接数为5 s.listen(5) # 接受连接,根据buffer_size不断读取内容 connection, address = s.accept() r = '' buffer_size = 1024 while 1: data = connection.recv(1024).decode('utf-8') r += data if len(data) < buffer_size: break # 防止浏览器传空请求过来 if len(r.split()) < 2: continue # 最后取得的r是一个http请求头字符串,对其解析,然后使用sendall返回相应的内容 request = Request(r) # 每次请求时打印时间,请求的方法和路径 print(str(datetime.now())[:19], request.method, request.path) response = response_for_request(request) connection.sendall(response) connection.close() if __name__ == '__main__': run_server()
run_server函数代码的简单说明可以看注释;from exts import Request:从exts导入一个Request类,这个Request类是自己编写的,用于解析http请求头,这部分是很简单的,在网上搜索http请求相关内容,就可以自行写一个,包括返回请求头的路径、方法、各个字段以及body部分等,都是字符串相关的操作。
from route import response_for_request:从route.py导入相应函数,即传入一个上一步中的Request类,返回对应的网页内容,具体实现将在后续讲解。
可以说,主程序就已经编写好了,整个逻辑也很简单,使用socket监听连接,解析请求,返回请求对应的内容。后续只要去处理解析请求和响应部分即可,主程序可以不用再修改。