返回固定页面
代码实现
import socket
if __name__ == '__main__':
# 创建tcp服务端套接字
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置端口号复用
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# 绑定端口号
tcp_server_socket.bind(("", 8000))
# 配置监听
tcp_server_socket.listen(128)
# 循环等待接收客户端的连接请求
while True:
new_socket, ip_port = tcp_server_socket.accept()
# 接收客户端的请求信息
recv_data = new_socket.recv(4096)
print("接收到客户端的信息为:", recv_data)
# 准备返回数据
# 打开文件读取文件中的数据,with open关闭文件无需程序员操作,系统自动关闭
with open("laifu.html", "r") as file: # file表示打开文件的对象
file_data = file.read()
# 响应行
response_line = "HTTP/1.1 200 OK\r\n"
# 响应头
response_header = "Server: LAIFU/1.0\r\n"
# 响应体
response_body = file_data
# 把数据封装成http响应报文格式的数据
response = response_line + response_header + "\r\n" + response_body
# 转换数据为二进制
response_data = response.encode("utf-8")
# 发送给客户端(浏览器)的响应报文数据
new_socket.send(response_data)
# 关闭服务与客户端的套接字
new_socket.close()
本地访问效果图
访问任何页面数据,都返回固定的页面
返回指定页面
代码实现
import socket
def main():
# 创建tcp服务端套接字
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置端口号复用
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# 绑定端口号
tcp_server_socket.bind(("", 8000))
# 配置监听
tcp_server_socket.listen(128)
# 循环等待接收客户端的连接请求
while True:
new_socket, ip_port = tcp_server_socket.accept()
# 接收客户端的请求信息
recv_data = new_socket.recv(4096)
# 判断如果客户端请求是空数据,则直接关闭服务套接字
if len(recv_data) == 0:
new_socket.close()
return
# 对二进制数据进行解码
recv_content = recv_data.decode("utf-8")
# 对数据按照空格进行分割
request_list = recv_content.split(" ", maxsplit=2)
# 获取请求的资源路径
request_path = request_list[1]
# 打印查看获取到的资源路径
print(request_path)
# 判断请求的是否为根路径,如果是设置默认返回图片
if request_path == "/":
request_path = "/test.jpeg"
# 准备返回数据
# 打开文件读取文件中的数据,with open关闭文件无需程序员操作,系统自动关闭
# 这里使用"rb"模式,兼容打开图片文件
with open("web" + request_path, "rb") as file: # file表示打开文件的对象
file_data = file.read()
# 响应行
response_line = "HTTP/1.1 200 OK\r\n"
# 响应头
response_header = "Server: LAIFU/1.0\r\n"
# 响应体
response_body = file_data
# 把数据封装成http响应报文格式的数据
response = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# 发送给客户端(浏览器)的响应报文数据
new_socket.send(response)
# 关闭服务与客户端的套接字
new_socket.close()
if __name__ == '__main__':
main()
本地访问效果图
访问页面数据,返回对应的页面;
访问根目录,默认返回指定页面
返回404页面
代码实现
import socket
import os
def main():
# 创建tcp服务端套接字
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置端口号复用
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# 绑定端口号
tcp_server_socket.bind(("", 8000))
# 配置监听
tcp_server_socket.listen(128)
# 循环等待接收客户端的连接请求
while True:
new_socket, ip_port = tcp_server_socket.accept()
# 接收客户端的请求信息
recv_data = new_socket.recv(4096)
# 判断如果客户端请求是空数据,则直接关闭服务套接字
if len(recv_data) == 0:
new_socket.close()
return
# 对二进制数据进行解码
recv_content = recv_data.decode("utf-8")
# 对数据按照空格进行分割
request_list = recv_content.split(" ", maxsplit=2)
# 获取请求的资源路径
request_path = request_list[1]
# 打印查看获取到的资源路径
print(request_path)
# 判断请求的是否为根路径,如果是设置默认返回图片
if request_path == "/":
request_path = "/test.jpeg"
# 判断此文件是否存在
# 第一种方法:os.path.exists
# os.path.exists("web/" + request_path)
# 第二种方法:try-except
try:
# 准备返回数据
# 打开文件读取文件中的数据,with open关闭文件无需程序员操作,系统自动关闭
# 这里使用"rb"模式,兼容打开图片文件
with open("web" + request_path, "rb") as file: # file表示打开文件的对象
file_data = file.read()
except Exception as e:
# 代码执行到此,说明没有请求的文件资源,返回404状态信息
# 响应行
response_line = "HTTP/1.1 404 Not Found\r\n"
# 响应头
response_header = "Server: LAIFU/1.0\r\n"
# 读取404页面数据
with open("web/error.html", "rb") as file:
file_data = file.read()
# 响应体
response_body = file_data
# 把数据封装成http响应报文格式的数据
response = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# 发送给客户端(浏览器)的响应报文数据
new_socket.send(response)
else: #代码执行到此,说明访问文件资源存在,返回200状态信息
# 响应行
response_line = "HTTP/1.1 200 OK\r\n"
# 响应头
response_header = "Server: LAIFU/1.0\r\n"
# 响应体
response_body = file_data
# 把数据封装成http响应报文格式的数据
response = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# 发送给客户端(浏览器)的响应报文数据
new_socket.send(response)
finally:
# 关闭服务与客户端的套接字
new_socket.close()
if __name__ == '__main__':
main()
访问效果图
访问不存在的资源时,返回指定404页面数据