思路:
? ? ? ? 1、创建监听套接字
? ? ? ? 2、绑定本地IP和port信息
? ? ? ? 3、使用listen改变监听状态
? ? ? ? 4、接收服务端链接,创建为客户端服务的客户端套接字
? ? ? ? 5、获取服务端发送的信息
? ? ? ? 6、使用正则表达式匹配客户端发送的信息,获得服务端需要的信息
? ? ? ? 7、根据匹配结果,在本地进行操作
? ? ? ? 8、发送匹配后的本地资源给客户端
? ? ? ? 9、关闭?客户端套接字,结束服务,等待下一个客户端链接。?
依赖的资源:
? ? ? ? 1、socket、re? ?包
? ? ? ? 2、自己创建或者放入同一目录下的img.html和3.pdf(都可以随意替换成你想要在浏览器展示的内容)
? ? ? ? 3、必须准备一个名为favicon格式为ico的图片,因为浏览器默认访问网站的时候会去取这张图片,展示为浏览器标签的左上角的图标。?
上代码:
from socket import *
import re
def client_sever(new_socket):
# 5、获取服务端发送的信息,并设置接收数据字节大小
request=new_socket.recv(1024).decode('utf-8')
# 6、使用正则表达式匹配客户端发送的信息,获得服务端需要的信息,本次匹配资源地址
g=re.match(r'[^/]*/+([^ ]*)\s+',request)
file_name=g.group(1)
# 7、根据匹配结果,在本地进行操作
# 打开本地资源,读取本地数据作为响应体
try: #执行代码
with open(file_name,'rb') as f:
response_body=f.read()
except: #发生异常时执行
response_body = '<h1>hello world!</h1>'.encode('utf-8')
finally: #不管有没有异常时,都会执行的代码
response_header = 'HTTP/1.1\r\n'
response_header += '\r\n'
print(file_name)
# 组装本地数据
response = response_header.encode('utf-8') + response_body
# 8、发送匹配后的本地资源给客户端
new_socket.send(response)
# 9、关闭客户端套接字,结束服务,等待下一个客户端链接。
new_socket.close()
def main():
# 1、创建监听套接字
server_socket=socket(AF_INET,SOCK_STREAM)
#server_socket.setblocking(False)
# 2、绑定本地IP和port信息,本地信息使用元组格式
server_socket.bind(('',8080))
# 3、使用listen改变监听状态,设置监听容量
server_socket.listen(128)
while True:
# 4、接收服务端链接,创建为客户端服务的客户端套接字
new_socket, client_addr = server_socket.accept()
# 调用函数方法为客户端服务
client_sever(new_socket)
if __name__ == '__main__':
main()
? ? ?注意:http协议头是文本形式, 以\r\n作为每个字段的分隔, 最后头部以两个\r\n结束, 所以我们主要构造好 http头, 浏览器就能识别接下来的正文
|