Web服务器之搭建指定页面的服务器

每日分享:

不将就

别因外界的声音放低自己的标准,要时刻相信自己值得。

该文章中代码是基于上一个文章代码做修改

上一文章链接:代码在这里

一、上一个静态Web服务器的问题

无论访问哪个网址,它只会返回一个固定的页面的数据,下面根据用户的请求返回对应的页面数据

返回用户指定页面数据的实现步骤:

  1. 获取用户请求资源的路径
  2. 根据请求资源的路径,读取指定文件的数据
  3. 组装指定文件数据的响应报文,发送给浏览器
  4. 判断请求的文件是否存在于服务端,若不存在,则组装404状态的响应报文,发送给浏览器

二、静态Web服务器---返回指定页面数据的代码

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(("", 1314))
    # 设置监听
    tcp_server_socket.listen(128)
    while True:
        # 等待接收客户端连接请求
        new_socket, ip_port = tcp_server_socket.accept()
        # 代码执行至此说明连接建立成功
        # 一次最多接收4KB
        recv_client_data = new_socket.recv(4096)
        # 对二进制数解码
        recv_client_content = recv_client_data.decode('utf-8')
        print(recv_client_content)
        if recv_client_content == '':
            return
        # 提取数据中的指定页面的name
        name = recv_client_content.split(" ", maxsplit=2)[1]
        # 如果用户输入的网址中没有任何指定页面信息,默认给客户端返回一个页面
        if name == '/':
            name = '/index1.html'
        try:
            # 打开文件,读取数据,r模式读取图片会报错,rb模式(二进制)可以读取图片
            with open("." + name, "rb") as f:
                file_data = f.read()
        except Exception as e:
            # 返回HTTP格式数据
            # 响应行
            response_line = "HTTP/1.1 400 Not Found\r\n"
            # 响应头
            response_header = "Sever: PWS6.6\r\n"
            with open('error.html', 'rb')as f:
                file_data = f.read()
            # 空行
            # 响应体
            response_body = file_data
            # 构建HTTP数据
            response = (response_line + response_header + "\r\n").encode('utf-8') + response_body
            # 发送数据
            new_socket.send(response)
        else:
            # 返回HTTP格式数据
            # 响应行
            response_line = "HTTP/1.1 200 OK\r\n"
            # 响应头
            response_header = "Sever: PWS6.6\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,用的是try方法,除了这个方法还可以用os.path.exists()来判断文件是否存在

三、小结

1. 获取用户请求资源的路径

name = recv_client_content.split(" ", maxsplit=2)[1]

2. 根据请求资源的路径,读取请求指定文件的数据

with open("." + name, "rb") as f:
    file_data = f.read()

3. 组装指定文件数据的响应报文,发送给浏览器

response = (response_line + response_header + "\r\n").encode('utf-8') + response_body
# 发送数据
new_socket.send(response)

4. 判断请求的文件若不存在于服务端,则组装404状态的响应报文发送给浏览器

try:

        # 打开指定文件……

except Exception as e:

        new_socket.send(404响应报文数据)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值