给程序传递参数,添加web服务器的配置文件,添加shell功能

 

#coding:utf-8
import sys

print(sys.argv)

# 运行次程序的方式: python3 xxx.py haha 7890
# 是一个列表,里边的项为用户输入的参数

 mini_frame

# coding:utf-8

def index():

    with open('./templates/index.html', 'r', encoding='UTF-8') as f:
        return  f.read()


def center():
    with open('./templates/center.html', 'r', encoding='UTF-8') as f:
        return f.read()


def application(env, start_response):
    start_response('200 OK', [('Content-Type', 'text/html;charset=utf-8'),('server', 'mini_frame v1.0')])

    file_name = env['PATH_INFO']

    if file_name == '/index.py':
        return index()
    elif file_name == '/center.py':
        return center()
    else:
        return 'Hello World!(๑′ᴗ‵๑)I Lᵒᵛᵉᵧₒᵤ❤中国'

 web_server.py

# coding:utf-8
import socket
import re
import multiprocessing
# import dynamic.mini_frame
import sys

class WSGIServer(object):

    def __init__(self, port, app, static_path):
        # 1.创建套接字
        self.tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        self.tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

        # 2.绑定地址
        self.tcp_server_socket.bind(('', port))

        # 3.变为监听套接字
        self.tcp_server_socket.listen(128)

        self.application = app  # 实例属性
        self.static_path = static_path  # 实例属性

    def service_client(self, new_socket):
        # 1.接收浏览器发送过来的请求,即http请求
        # GET / HTTP/1.1
        requset = new_socket.recv(1024).decode('utf-8')
        requset_lines = requset.splitlines()
        print(requset_lines)

        file_name = ''
        ret = re.match(r'[^/]+(/[^ ]*)', requset_lines[0])

        if ret:
            file_name = ret.group(1)
            if file_name == "/":
                file_name = '/index.html'


        # 2.返回http格式的数据给浏览器
        # 2.1 如果请求的资源部署以.py结尾,那么就认为是静态资源(http/css/js/png/jpg等)
        if not file_name.endswith('.py'):
            try:
                f = open(self.static_path + file_name, 'rb')
            except:
                response = 'HTTP/1.1 404 NOT FOUND\r\n'
                response += '\r\n'
                response += '---------file not found---------'
                new_socket.send(response.encode('utf-8'))
            else:
                html_content = f.read()
                response = 'HTTP/1.1 200 OK\r\n'
                response += '\r\n'
                # header发送给服务器
                new_socket.send(response.encode('utf-8'))
                # body发送给服务器
                new_socket.send(html_content)
        else:
            # 2.2 如果是以.py结尾,那么就认为是动态资源的请求

            env = dict()
            env['PATH_INFO'] = file_name
            body = self.application(env, self.set_response_header)
            header = 'HTTP/1.1 %s\r\n' % self.status

            for temp in self.headers:
                header += '%s:%s\r\n' % (temp[0], temp[1])

            header += '\r\n'

            response = header + body

            # 发送response给浏览器
            new_socket.send(response.encode('utf-8'))
        # 关闭套接字
        new_socket.close()

    def set_response_header(self, status, headers):
        self.status = status
        self.headers = headers

    def run_forever(self):

        while True:
            # 等待客户端连接
            new_socket, client_addr = self.tcp_server_socket.accept()

            p = multiprocessing.Process(target=self.service_client, args=(new_socket,))
            p.start()

            new_socket.close()

        self.tcp_server_socket.close()


def main():
    '''控制整体,创建一个web服务器对象,然后调用这个对象的run_forever方法运行'''
    if len(sys.argv) == 3: # 传入三个参数
        try:
            port = int(sys.argv[1])  # 端口
            frame_app_name = sys.argv[2]  # mini_frame
        except Exception as ret:
            print('端口输入错误....')
            return

    else:
        print('请按照以下方式运行:')
        print('python3 xxxx.py 7890 mini_frame:application')
        return  # retrun 不写值=结束任务


    # mini_frame:application
    ret = re.match(r'([^:]+):(.*)', frame_app_name)
    if ret:
        frame_name = ret.group(1)  # mini_frame
        app_name = ret.group(2)  # application
    else:
        print('请按照以下方式运行:')
        print('python3 xxxx.py 7890 mini_frame:application')
        return  # retrun 不写值=结束任务

    with open('./web_server.conf') as f:
        conf_info = eval(f.read())  #  控制文件转为字典
        #{
        #    'static_path': './static',
        #    'dynamic_path': './dynamic'
        #}

    sys.path.append(conf_info['dynamic_path'])  #  添加路径

    # import frame_name  -->找frame_name.py ×
    frame = __import__(frame_name)  # 返回值标记着导入的这个模块
    app = getattr(frame, app_name)  # 此时app就指向了dynamic/mini_frame模块的application函数

    wsgi_server = WSGIServer(port, app, conf_info['static_path'])
    wsgi_server.run_forever()


if __name__ == '__main__':
        main()

web_server.conf 

{
    'static_path':'./static',
    'dynamic_path':'./dynamic'

}

shell脚本

ls -lh  # 查看文件权限
chmod +x run.sh  # 授权执行

python3 web_server.py 7890 mini_frame:application

./run.sh  # 执行

readme.text

-------copyright版权-----------
linux系统

运行方式:./run.sh
或者 python3 xxx.py 7890 mini_frame:application

author:laowang
date:2020-06-05
version:1.0

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值