鱼C论坛

 找回密码
 立即注册
查看: 1876|回复: 3

我在写动态资源请求框架时,遇到无法解决的问题,求助

[复制链接]
发表于 2020-12-27 22:09:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我在写动态资源请求框架时,在实现路由列表功能时,浏览器不能解析我的web服务器返回的数据.
代码错误提示是:UnicodeDecodeError: 'gbk' codec can't decode byte 0xaa in position 214: illegal multibyte sequence
1.虽然提示的是Unicode解码错误,但是我把编码全部换成gbk,仍然没解决bug,
2. illegal multibyte sequence 不合法的多字节序列问题提示,我始终没找出代码中有什么序列是不合法的,这应该是产生问题的原因.
简易的web框架代码如下:
  1. import time

  2. def index():
  3.     # 响应状态
  4.     status = "200 OK"
  5.     # 响应头
  6.     response_header = [("Server", "PWS2.0")]

  7.     # 1. 打开模板文件,读取数据
  8.     with open("template/index.html", "r") as file:
  9.         file_data = file.read()

  10.     # 处理后的数据, 从数据库查询
  11.     data = time.ctime()
  12.     # 2. 替换模板文件中的模板遍历
  13.     result = file_data.replace("{%content%}", data)

  14.     return status, response_header, result

  15. def center():
  16.     # 响应状态
  17.     status = "200 OK"
  18.     # 响应头
  19.     response_header = [("Server", "PWS2.0")]

  20.     # 打开模板文件,读取数据
  21.     with open("template/center.html", "r") as file:
  22.         file_data = file.read()

  23.     # 处理后的数据, 从数据库查询
  24.     data = time.ctime()
  25.     # 替换模板文件中的模板遍历
  26.     result = file_data.replace("{%content%}", data)

  27.     return status, response_header, result


  28. route_list = [
  29.     ("/index.html", index),
  30.     ("/center.html", center)
  31. ]


  32. def not_found():
  33.     # 响应行,响应头,响应体信息
  34.     status = "404 NOT FOUND"
  35.     response_header = [("Server", "PWS/1.1")]
  36.     data = "not found"

  37.     return status, response_header, data


  38. def handle_request(env):
  39.     # 获取动态请求资源路径
  40.     request_path = env["request_path"]
  41.     print("接收到的动态资源请求:", request_path)
  42.     for path, func in route_list:
  43.         if request_path == path:
  44.             result = func()
  45.             return result
  46.     else:
  47.         # 没有找到动态资源
  48.         result = not_found()
  49.         return result
复制代码


web服务器的代码如下:
  1. import socket
  2. import threading
  3. import sys
  4. import frame_work


  5. # 定义web服务器类
  6. class HttpWebServer(object):
  7.     def __init__(self, port):
  8.         # 创建tcp服务端套接字
  9.         tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  10.         # 设置端口号复用, 程序退出端口立即释放
  11.         tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
  12.         # 绑定端口号
  13.         tcp_server_socket.bind(("", port))
  14.         # 设置监听
  15.         tcp_server_socket.listen(128)
  16.         self.tcp_server_socket = tcp_server_socket

  17.     # 处理客户的请求
  18.     @staticmethod
  19.     def handle_client_quest(new_socket):
  20.         # 代码执行到此,说明连接建立成功
  21.         recv_client_data = new_socket.recv(4096)
  22.         if len(recv_client_data) == 0:
  23.             print("关闭浏览器了")
  24.             # 关闭服务与客户端的套接字
  25.             new_socket.close()
  26.             return

  27.         # 对二进制数据进行解码
  28.         recv_client_content = recv_client_data.decode("utf-8")
  29.         print(recv_client_content)
  30.         # 根据指定字符串进行分割, 最大分割次数指定2
  31.         request_list = recv_client_content.split(" ", maxsplit=2)

  32.         # 获取请求资源路径
  33.         request_path = request_list[1]
  34.         print(request_path)

  35.         # 判断请求的是否是根目录,如果条件成立,指定首页数据返回
  36.         if request_path == "/":
  37.             request_path = "/index.html"

  38.         # 判断是否是动态资源请求
  39.         if request_path.endswith(".html"):
  40.             """这里是动态资源请求,把请求信息交给框架处理"""
  41.             # 字典存储用户的请求信息
  42.             env = {
  43.                 "request_path": request_path
  44.             }

  45.             # 获取处理结果
  46.             status, headers, response_body = frame_work.handle_request(env)

  47.             # 使用框架处理的数据拼接响应报文
  48.             # 响应行
  49.             response_line = "HTTP/1.1 %s\r\n" % status
  50.             # 响应头
  51.             response_header = ""
  52.             # 遍历头部信息
  53.             for header in headers:
  54.                 # 拼接多个响应头
  55.                 response_header += "%s: %s\r\n" % header
  56.             response_data = (response_line +
  57.                              response_header +
  58.                              "\r\n" +
  59.                              response_body).encode("utf-8")
  60.             # 发送数据
  61.             new_socket.send(response_data)
  62.             # 关闭socket
  63.             new_socket.close()

  64.         else:
  65.             """这里是静态资源请求"""
  66.             try:
  67.                 # 动态打开指定文件
  68.                 with open("static" + request_path, "rb") as file:
  69.                     # 读取文件数据
  70.                     file_data = file.read()
  71.             except Exception as e:
  72.                 # 请求资源不存在,返回404数据
  73.                 # 响应行
  74.                 response_line = "HTTP/1.1 404 Not Found\r\n"
  75.                 # 响应头
  76.                 response_header = "Server: PWS1.0\r\n"
  77.                 with open("static/error.html", "rb") as file:
  78.                     file_data = file.read()
  79.                 # 响应体
  80.                 response_body = file_data

  81.                 # 拼接响应报文
  82.                 response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
  83.                 # 发送数据
  84.                 new_socket.send(response_data)
  85.             else:
  86.                 # 响应行
  87.                 response_line = "HTTP/1.1 200 OK\r\n"
  88.                 # 响应头
  89.                 response_header = "Server: PWS1.0\r\n"

  90.                 # 响应体
  91.                 response_body = file_data

  92.                 # 拼接响应报文
  93.                 response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
  94.                 # 发送数据
  95.                 new_socket.send(response_data)
  96.             finally:
  97.                 # 关闭服务与客户端的套接字
  98.                 new_socket.close()

  99.     def start(self):
  100.         while True:
  101.             # 等待接受客户端的连接请求
  102.             new_socket, ip_port = self.tcp_server_socket.accept()
  103.             sub_thread = threading.Thread(target=self.handle_client_quest, args=(new_socket,))
  104.             # 设置守护线程
  105.             sub_thread.setDaemon(True)
  106.             sub_thread.start()


  107. # 程序入口函数
  108. def main():

  109.     # 获取命令行参数判断长度
  110.     # if len(sys.argv) != 2:
  111.     #     print("执行命令如下: python3 xxx.py 9000")
  112.     #     return
  113.     #
  114.     # # 判断端口号是否是数字
  115.     # if not sys.argv[1].isdigit():
  116.     #     print("执行命令如下: python3 xxx.py 9000")
  117.     #     return
  118.     #
  119.     # # 需要转成int类型
  120.     # port = int(sys.argv[1])

  121.     # 创建web服务器
  122.     web_server = HttpWebServer(8000)
  123.     # 启动web服务器
  124.     web_server.start()


  125. if __name__ == '__main__':
  126.     main()
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-12-27 22:10:58 | 显示全部楼层
真心求教大佬们,自学真的太难了.
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-27 22:24:31 | 显示全部楼层
求各位大佬帮帮小弟吧,谢谢了!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-28 09:52:39 | 显示全部楼层
不懂,帮顶
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-29 19:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表