tcp服务器根据路径返回不同网页静态版

import socket
import re


def main():

#服务器tcp服务器对象
tcp_server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)


#设置我们的端口地址重用
tcp_server.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)


#绑定端口号
tcp_server.bind(("",6789))
#改成被动模式
tcp_server.listen(True)
#循环去处理客户请求
while True:
client,addr = tcp_server.accept()
# print(addr)


#接收数据
data = client.recv(1024).decode()
head_lines = data.splitlines()
try:
print(head_lines[0])
#GET /index.html HTTP/1.1
#使用正则去获取地址
re_match = re.match(r'[^/]+(/[^ ]*)', head_lines[0])
#判断是否匹配了
if re_match: #匹配 了
file_name = re_match.group(1)
#如果是/那么去首页
if file_name == "/":
file_name = "/index.html"
except Exception as e:
print(e)  #工作中是记录到文件

#返回数据
#响应头
#空行
#响应体
try:
headers = "HTTP/1.1 200 OK\r\n"
#会根据不同的地址返回不的内容
#打开文件写读文件内容
with open("./html%s"%file_name,'rb') as f:   #这样写有一个好处,如果是图片就不会有问题
body = f.read() #读取文件

# body = "show page is find!"

# content = headers +"\r\n" +body
content = headers +"\r\n"

# client.send(content.encode("utf-8"))
client.send(content.encode("utf-8"))
client.send(body)
except Exception as e:
print(e)
#返回一个404的正常显示的页面
head = "HTTP/1.1 404 NOT FIND\r\n"
body = "not find page!"
content = head + "\r\n" + body

client.send(content.encode("utf-8"))

#关闭客户端
client.close()
#关闭服务器
tcp_server.close()

if __name__ == '__main__':
    main()
阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页