zoukankan      html  css  js  c++  java
  • python之web框架(1):完成静态页面web服务器

    python的web框架(1)

    1.首先写一个最简单的web服务器,只能给客户回应一个固定的hello world的页面。

    from socket import *
    from multiprocessing import Process
    
    
    def deal(conn):
        recv_data = conn.recv(1024).decode('gb2312')
        print(recv_data)
        conn.send('HTTP/1.1 200 OK 
    
     <h1>hello world</h1>'.encode('gb2312'))
    
    def main():
        s = socket(AF_INET, SOCK_STREAM)
        s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
        s.bind(('',8000))
        s.listen(1023)
    
        while 1:
            conn, user_info = s.accept()
            print(user_info)
            p = Process(target=deal, args=(conn,))
            p.start()
            conn.close()
    
    
    if __name__ == '__main__':
        main()
    
    

    2.根据用户请求的页面,打开页面文件,读取,并回复给用户,完成多进程web静态页面服务器

    #!/usr/bin/env python3
    # coding:utf-8
    
    from socket import *
    from multiprocessing import Process
    
    
    def deal(conn):
        recv_data = conn.recv(1024).decode('gb2312')
        recv_data_head = recv_data.splitlines()[0]
        print('------', recv_data_head)
        request_method, request_path, http_version = recv_data_head.split()
    
        # 去掉url中的?和之后的参数
        request_path = request_path.split('?')[0]
    
        if request_path == '/':
            request_path = '/index.html'
        file_name = "." + request_path
        try:
            f = open(file_name, 'rb')
        except IOError:
            conn.send(b'HTTP/1.1 404 ERROR 
    
     <h1>Page is not exsit .</h1>')
            return
    
        read_data = f.read()
        send_data = b'HTTP/1.1 200 OK 
    
    ' + read_data
        conn.send(send_data)
        f.close()
    
    
    def main():
        s = socket(AF_INET, SOCK_STREAM)
        s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
        s.bind(('',8000))
        s.listen(1023)
    
        while 1:
            conn, user_info = s.accept()
            print(user_info)
            p = Process(target=deal, args=(conn,))
            p.start()
            conn.close()  # 进程会复制出一个新的conn,所以这里的conn需要关闭
    
    
    if __name__ == '__main__':
        main()
    
    

    3.为了方便操作,可以将之前的函数式编程改成面向对象编程。将所有的方法集成到一个类中,这样更加方便,也更易于使用者了解和使用。

    #!/usr/bin/env python3
    # coding:utf-8
    
    from socket import *
    from multiprocessing import Process
    
    
    class MyWebServer(object):
    
        @staticmethod
        def deal(conn):
            recv_data = conn.recv(1024).decode('gb2312')
            recv_data_head = recv_data.splitlines()[0]
            print('------', recv_data_head)
            request_method, request_path, http_version = recv_data_head.split()
    
            # 去掉url中的?和之后的参数
            request_path = request_path.split('?')[0]
    
            if request_path == '/':
                request_path = '/index.html'
            file_name = "." + request_path
    
            try:
                f = open(file_name, 'rb')
            except IOError:
                conn.send(b'HTTP/1.1 404 ERROR 
    
     <h1>Page is not exsit .</h1>')
                return
    
            read_data = f.read()
            send_data = b'HTTP/1.1 200 OK 
    
    ' + read_data
            conn.send(send_data)
            f.close()
    
        def __init__(self):
            self.s = socket(AF_INET, SOCK_STREAM)
            self.s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
            self.s.bind(('',8000))
            self.s.listen(1023)
    
        def start(self):
            while 1:
                conn, user_info = self.s.accept()
                print(user_info)
                p = Process(target=self.deal, args=(conn,))
                p.start()
                conn.close()  # 进程会复制出一个新的conn,所以这里的conn需要关闭
    
    
    s = MyWebServer()
    s.start()
    
    

  • 相关阅读:
    Hoder.js介绍
    vim折叠方法
    tensorflow最基础分类实例--iris分类
    语音识别GMM-HMM
    亨元模式
    责任链模式
    命令模式
    策略模式
    工厂模式
    Java高并发程序设计(十)--无锁
  • 原文地址:https://www.cnblogs.com/PrettyTom/p/6720832.html
Copyright © 2011-2022 走看看