龙空技术网

搭建Python自带静态Web服务器

VT聊球 261

前言:

现时我们对“python自带服务器”大致比较关注,咱们都想要剖析一些“python自带服务器”的相关内容。那么小编也在网摘上网罗了一些对于“python自带服务器””的相关知识,希望小伙伴们能喜欢,姐妹们快快来学习一下吧!

静态web服务器是什么?

可以为发出请求的浏览器提供静态文档的程序。

平时我们浏览新闻数据的时候,每天的新闻数据都会发生变化,那访问的这个页面就是动态的,而我们开发的是静态的,页面的数据不会发生变化。

如何搭建Python自带的静态Web服务器

搭建Python自带的静态web服务器使用 python -m http.server 端口号,端口号不指定默认8000

-m选项说明:

-m表示运行包里面的模块,执行这个命令的时候,需要进入你自己指定静态文件的目录,然后通过浏览器就能访问对应的html文件了,这样一个静态的web服务器就搭建好了。静态web服务器-返回固定页面数据

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)        # 打开文件,读取文件中的数据        # 这里的file表示打开文件的对象        with open('static/index.html', 'r') as file:            file_data = file.read()        # 提示:with open 关闭文件这步操作不用程序员书写,系统自动完成        # 响应行        response_line = 'HTTP/1.1 200 OK\r\n'        # 响应头        response_header = 'Server: PWS/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()
静态web服务器-返回指定页面数据
import socketimport osdef 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)        # 判断接收的数据长度是否为0        if len(recv_data) == 0:            new_socket.close()            return        # 对二进制数据进行解码        recv_content = recv_data.decode('utf-8')        print(recv_content)        # 对数据按照空格进行分割        request_list = recv_content.split(' ', maxsplit=2)        # 获取请求的资源路径        request_path = request_list[1]        print(request_path)        # 判断请求的是否是根目录,如果是,设置根目录        if request_path == '/':            request_path = '/index.html'        # 1. os.path.exists        # os.path.exists('static/' + request_path)        # 2. try-except        try:            # 打开文件,读取文件中的数据,这里使用rb模式,兼容打开图片文件            # 这里的file表示打开文件的对象            with open('static' + request_path, 'rb') as file:                file_data = file.read()            # 提示:with open 关闭文件这步操作不用程序员书写,系统自动完成        except Exception as e:            # 代码执行到此,说明没有请求的该文件,返回404状态信息            # 响应行            response_line = 'HTTP/1.1 404 Not Found\r\n'            # 响应头            response_header = 'Server: PWS/1.0\r\n'            # 读取404页面数据            with open('static/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)            pass        else:            # 代码执行到此,说明文件存在,返回200状态信息            # 响应行            response_line = 'HTTP/1.1 200 OK\r\n'            # 响应头            response_header = 'Server: PWS/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()
静态web服务器-多任务版
import socketimport threading# 处理客户端请求def handle_client_request(new_socket):    # 接收客户端的请求信息    recv_data = new_socket.recv(4096)    # 判断接收的数据长度是否为0    if len(recv_data) == 0:        new_socket.close()        return    # 对二进制数据进行解码    recv_content = recv_data.decode('utf-8')    print(recv_content)    # 对数据按照空格进行分割    request_list = recv_content.split(' ', maxsplit=2)    # 获取请求的资源路径    request_path = request_list[1]    print(request_path)    # 判断请求的是否是根目录,如果是,设置根目录    if request_path == '/':        request_path = '/index.html'    # 1. os.path.exists    # os.path.exists('static/' + request_path)    # 2. try-except    try:        # 打开文件,读取文件中的数据,这里使用rb模式,兼容打开图片文件        # 这里的file表示打开文件的对象        with open('static' + request_path, 'rb') as file:            file_data = file.read()        # 提示:with open 关闭文件这步操作不用程序员书写,系统自动完成    except Exception as e:        # 代码执行到此,说明没有请求的该文件,返回404状态信息        # 响应行        response_line = 'HTTP/1.1 404 Not Found\r\n'        # 响应头        response_header = 'Server: PWS/1.0\r\n'        # 读取404页面数据        with open('static/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)        pass    else:        # 代码执行到此,说明文件存在,返回200状态信息        # 响应行        response_line = 'HTTP/1.1 200 OK\r\n'        # 响应头        response_header = 'Server: PWS/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()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()        # 代码执行到此,说明连接建立成功        sub_thread = threading.Thread(target=handle_client_request, args=(new_socket,))        # 设置成为守护主线程        sub_thread.setDaemon(True)        # 启动子线程执行对应的任务        sub_thread.start()# 判断是否是主模块的代码if __name__ == '__main__':    main()
静态web服务器-面向对象开发

实现步骤

把提供服务的web度武器抽象成一个类(HTTPWebServer)提供web服务器的初始化方法,在初始化方法里面创建socket对象提供一个开启web服务器的方法,让web服务器处理客户端请求操作

import socketimport threading# http协议的web服务器类class HttpWebServer(object):    def __init__(self):        # 创建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)        # 把tcp服务端的套接字作为web服务器对象的属性        self.tcp_server_socket = tcp_server_socket    # 启动服务器的方法    def start(self):        # 循环等待接受客户端的连接请求        while True:            # 等待接受客户端的连接请求            new_socket, ip_port = self.tcp_server_socket.accept()            # 代码执行到此,说明连接建立成功            sub_thread = threading.Thread(target=self.handle_client_request, args=(new_socket,))            # 设置成为守护主线程            sub_thread.setDaemon(True)            # 启动子线程执行对应的任务            sub_thread.start()    # 处理客户端请求    @staticmethod    def handle_client_request(new_socket):        # 接收客户端的请求信息        recv_data = new_socket.recv(4096)        # 判断接收的数据长度是否为0        if len(recv_data) == 0:            new_socket.close()            return        # 对二进制数据进行解码        recv_content = recv_data.decode('utf-8')        print(recv_content)        # 对数据按照空格进行分割        request_list = recv_content.split(' ', maxsplit=2)        # 获取请求的资源路径        request_path = request_list[1]        print(request_path)        # 判断请求的是否是根目录,如果是,设置根目录        if request_path == '/':            request_path = '/index.html'        # 1. os.path.exists        # os.path.exists('static/' + request_path)        # 2. try-except        try:            # 打开文件,读取文件中的数据,这里使用rb模式,兼容打开图片文件            # 这里的file表示打开文件的对象            with open('static' + request_path, 'rb') as file:                file_data = file.read()            # 提示:with open 关闭文件这步操作不用程序员书写,系统自动完成        except Exception as e:            # 代码执行到此,说明没有请求的该文件,返回404状态信息            # 响应行            response_line = 'HTTP/1.1 404 Not Found\r\n'            # 响应头            response_header = 'Server: PWS/1.0\r\n'            # 读取404页面数据            with open('static/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)            pass        else:            # 代码执行到此,说明文件存在,返回200状态信息            # 响应行            response_line = 'HTTP/1.1 200 OK\r\n'            # 响应头            response_header = 'Server: PWS/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()def main():    # 创建web服务器    web_server = HttpWebServer()    # 启动服务器    web_server.start()# 判断是否是主模块的代码if __name__ == '__main__':    main()
获取终端命令行参数
import sys# 获取终端命令行参数params = sys.argv# 列表里面的每项数据都是字符串类型print(params, type(params))
静态web服务器-命令行启动动态绑定端口号

实现步骤

获取执行python程序的终端命令行参数判断参数的类型,设置端口号必须是整型给web服务器的初始化方法添加一个端口号参数,用于绑定端口号

import socketimport threadingimport sys# http协议的web服务器类class HttpWebServer(object):    def __init__(self, port):        # 创建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(('', port))        # 设置监听        tcp_server_socket.listen(128)        # 把tcp服务端的套接字作为web服务器对象的属性        self.tcp_server_socket = tcp_server_socket    # 启动服务器的方法    def start(self):        # 循环等待接受客户端的连接请求        while True:            # 等待接受客户端的连接请求            new_socket, ip_port = self.tcp_server_socket.accept()            # 代码执行到此,说明连接建立成功            sub_thread = threading.Thread(target=self.handle_client_request, args=(new_socket,))            # 设置成为守护主线程            sub_thread.setDaemon(True)            # 启动子线程执行对应的任务            sub_thread.start()    # 处理客户端请求    @staticmethod    def handle_client_request(new_socket):        # 接收客户端的请求信息        recv_data = new_socket.recv(4096)        # 判断接收的数据长度是否为0        if len(recv_data) == 0:            new_socket.close()            return        # 对二进制数据进行解码        recv_content = recv_data.decode('utf-8')        print(recv_content)        # 对数据按照空格进行分割        request_list = recv_content.split(' ', maxsplit=2)        # 获取请求的资源路径        request_path = request_list[1]        print(request_path)        # 判断请求的是否是根目录,如果是,设置根目录        if request_path == '/':            request_path = '/index.html'        # 1. os.path.exists        # os.path.exists('static/' + request_path)        # 2. try-except        try:            # 打开文件,读取文件中的数据,这里使用rb模式,兼容打开图片文件            # 这里的file表示打开文件的对象            with open('static' + request_path, 'rb') as file:                file_data = file.read()            # 提示:with open 关闭文件这步操作不用程序员书写,系统自动完成        except Exception as e:            # 代码执行到此,说明没有请求的该文件,返回404状态信息            # 响应行            response_line = 'HTTP/1.1 404 Not Found\r\n'            # 响应头            response_header = 'Server: PWS/1.0\r\n'            # 读取404页面数据            with open('static/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)            pass        else:            # 代码执行到此,说明文件存在,返回200状态信息            # 响应行            response_line = 'HTTP/1.1 200 OK\r\n'            # 响应头            response_header = 'Server: PWS/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()def main():    # 获取终端命令行参数    params = sys.argv    if len(params) != 2:        print('执行的命令格式如下:python xxx.py 9000')        return    # 判断第二个参数是否都是由数字组成的字符串    if not params[1].isdigit():        print('执行的命令格式如下:python xxx.py 9000')        return    # 代码执行到此,说明命令行参数的个数一定是两个,并且第二个是由数字组成的字符串    port = int(params[1])    # 创建web服务器    web_server = HttpWebServer(port)    # 启动服务器    web_server.start()# 判断是否是主模块的代码if __name__ == '__main__':    main()

标签: #python自带服务器