纯手撸Web框架
1. 纯手撸Web框架
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time: 2021/9/24 13:34
# @Author: 小梁同学@0311
# @Software: PyCharm
import socket
server = socket.socket() # TCP 三次握手 四次挥手 osi七层
server.bind(('127.0.0.1', 8081)) # IP协议 以太网协议 arp协议
server.listen(5) # 类似一个池的概念(进程池/线程池)
while True:
conn, addr = server.accept()
data = conn.recv(1024) # 二进制数据
print(data.decode('utf-8')) # 将二进制数据解码成字符串
data = data.decode('utf-8')
conn.send(b'HTTP/1.1 200 OK\r\n\r\n') # http协议,防止报错 无法访问此网站 127.0.0.1 拒绝了我们的连接请求。
# 获取字符串中特定的内容
'''
1、正则
2、如果字符串有规律也可以考虑用切割
'''
current_path = data.split(' ')[1]
# print(current_path)
if current_path == '/home':
# conn.send('我是主页-home'.encode('utf-8'))
with open(r'E:\project-python\Django_item\templates\my_first_html.html', 'rb') as f:
conn.send(f.read())
elif current_path == '/login':
conn.send('This is login page'.encode('utf-8'))
else:
conn.send('hello,Django sister'.encode('utf-8'))
conn.close()
2. my_first_html.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>我的第一个HTML</title>
</head>
<body>
<h1>
我是1号标题...
</h1>
</body>
</html>
不足之处
1、代码重复(服务端代码所有人都要重复写)
2、手动处理http格式的数据 并且只能拿到url后缀 其他数据获取繁琐(数据格式一样,处理的diamante也大致一致 重复写)
3、并发问题