«

怎么使用Python实现一个简单的Web应用框架

时间:2024-5-1 10:23     作者:韩俊     分类: Python


本文小编为大家详细介绍“怎么使用Python实现一个简单的Web应用框架”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用Python实现一个简单的Web应用框架”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    写应用框架需要写底层服务器么

    这个要区分2种情况,如果应用框架,你没有参考

    WSGI
    标准,那么在写应用框架之前,你就必须要定义一套属于自己的服务器,当然本文不采取这种方式,专业的事情应该专业的人来做。我们将编写符合
    WSGI
    标准的框架 ,所以仅需要引入符合
    WSGI
    的服务器即可,

    那么有哪些

    wsgi
    服务器呢? 这里简单列举2个

      uwsgi
      :该服务器是使用
      c
      编写的,具有广泛的应用场景的应用程序容器。除了支持
      WSGI
      外,还支持其他协议,例如
      HTTP
      WebSocket
      等等。不仅如此,它还提供了多进程、多线程、协程、异步IO等多种运行模式,还提供了很多高级功能,如内存共享、定时任务、快速热部署等。

      waitress
      :该服务器是使用
      python
      写的,是一个很轻量级、非常可靠、支持多线程的
      WSGI
      服务器,可以用来运行
      Python Web
      应用。

    我们本篇文章的

    web
    框架采用的就是
    uswgi

    uwsgi基本使用

    上面已经简单介绍了

    uwsgi
    的信息,本段落会简单介绍一下
    uwsgi
    安装和简单的配置。

    安装uwsgi

    安装

    uwsgi
    ,在
    python
    中,直接使用
    pip
    安装即可,例如:

     pip3 install uwsgi

    配置uwsgi

    uwsgi
    支持多种格式,可以直接在命令行上,例如:

    uwsgi --http :8080 --wsgi-file myapp.py --callable app

    还可以将上述写到命令中,例如:

    uwsgi --ini myapp.ini

    其中

    myapp.ini
    内容如下:

    [uwsgi]
    http = :8080
    wsgi-file = myapp.py
    callable = app

    不仅如此,

    uwsgi
    还支持多个格式,例如:
    xml
    yaml
    json
    等。

    配置文件也可以是

    url
    的形式,例如:

    uwsgi --ini http://127.0.0.1:8080/myapp.ini

    uwsgi常用配置

    指定启动

    uwsgi
    进程的用户和用户组

    uid=pdudo
    gid=pdudoGroups

    上述启动

    uwsgi
    进程使用
    pdudo
    用户,而组的话是使用
    pdudoGroups

    指定项目名称

    使用

    project
    来指定项目名称,如
    project=pdudoProject

    指定进程家目录

    使用

    base
    来指定进程家目录,如
    base=/home/pdudo/

    设置进程数

    要设置进程数,需要先将

    master
    设置为
    True
    , 而后再设置
    process
    个数,一把建议进程数不超过
    cpu
    核数,例如:

    master=True
    process=16

    设置对外

    http
    地址

    若想对外,有很多中配置,如

    socket
    等,但是一般用的最多的还是
    http
    ,我们直接指向一个套接字地址即可,例如:

    http=0.0.0.0:8000

    uwsgi启服和停服

    启动服务器

    直接使用

    uwsgi
    即可启动配置,如:

     uwsgi

    若不想设置配置文件,直接可以在命令行启动,如:

    uwsgi --http :8080

    若想通过配置文件启动,则可以使用加载配置选项即可,例如:

    ini
    中读取配置启动服务器

    uwsgi -ini app.ini

    json
    中读取配置启动服务器

    uwsgi --json app.json

    uwsgi
    中,可以通过向进程发送信号的方式,来关闭服务器,对应的信号为:
    SIGINT

    关闭服务器

    kill -2 uwsgiPID

    启动一个demo

    我们将使用

    uwsgi
    来启动一个简单的
    demo
    ,首先我们来编写符合
    WSGI
    标准的应用,例如,我们的
    demo
    为:

    def application(environ, start_response):
        status = "200 OK"
        headers = [("Content-type","text/html"),("Server","pdudo_web_sites")]
        start_response(status,headers)
        return [b'Hello, pdudos.']

    上述代码,我们定义了一个函数

    application
    ,形参为
    environ
    以及
    start_response
    ,前则是一个字典,后则是一个函数,在
    application
    中,需要定义请求的状态和短语,以及响应头。 而后调用
    start_response
    函数,需要传入状态和响应头。最后将返回一个报文主体。

    如果这块,不太明白的话,可以看一下

    wsgi
    标准。

    我们将这个上述代码保存为

    main.py
    ,而后使用
    uwsgi
    来启动该项目:

    uwsgi --http :8080 --wsgi-file main.py

    上述代码,使用的命令行的方式来启动

    uwsgi
    ,指定
    http
    端口为
    8080
    ,监听的网卡没有指定,默认是所有网卡,从
    swgi-file
    将指定我们自己写的
    wsgi
    应用程序。

    启动后,我们使用

    curl -v 127.0.0.1:8080/123
    可以得到如下信息:

    写一个简单的web应用框架

    本篇文章,很大部分都在描述

    uwgi
    ,这是因为我们将选用其为
    web
    服务器,所以很大的篇章都在描述它,现在,我们已经会基本的操作了,我们应该来写一个简单的
    web
    框架了。

    我们写的

    web
    框架如下:

    webRoute = {}
    def application(environ, start_response):
        path = environ['PATH_INFO']
        if webRoute[path]:
            func = webRoute[path]
            code , body = func(environ)
            status = "%d OK" % (code)
            headers = [("Content-type","text/html"),("Server","pdudo_web_sites")]
            start_response(status,headers)
            return [body.encode()]
    def Routes(path,func):
        print("add routes: %s %s" %(path,func))
        webRoute[path] = func

    哎,短短17行,我们基本的框架就写完了,厉害吧,我们将次代码保存到本地,命名为

    myWeb.py
    ,目的是和逻辑代码分开。上述代码,我们定义了一个
    webRoute
    字典来存储路由信息,我们想要存储
    key
    为请求的
    url
    ,值为可被调用的函数。

    我们为此专门写了一个

    Routes
    函数,该函数将传入2个值,第一个是请求的
    url
    ,第二个是可被调用的函数。

    application
    中,会首先获取请求的路径,而后再根据
    webRoute
    的值,进行匹配,若匹配到了,则执行该函数,该函数必须2个值,第一个是状态码,第二个是响应报文主体。 我们将根据返回的信息,组合成状态码以及响应头,通过调用
    start_response
    函数,将2个参数携带上,最后
    return
    一个报文主体。

    接下里,我们就可以写我们的逻辑代码了,我们编写如下:

    import myWeb
    app = myWeb.application
    def index(*args):
        return (200,"hello world")
    def d345(*args):
        return (400,"dasda")
    myWeb.Routes("/index",index)
    myWeb.Routes("/123",d345)

    我们将上述代码保存到本地,命名为

    main.py

    上述代码,我们先引用了刚刚保存到本地的

    myWeb
    文件,定义一个变量
    app
    用于引用
    myWeb.application
    函数。接着,我们便定义了2个函数,分别是
    index
    d345
    ,2个函数的共同之处是返回了一个元组,元组前者是int类型,将用于状态码,后则是
    str
    类型,将用于返回响应报文主体。

    最后,我们通过

    myWeb.Routes
    将2个函数于路由串联起来,分别对应为:

      /index
      :
      index
      函数。

      /123
      :
      d456
      函数

    我们应用框架就写完了,我们需要使用

    uwsgi
    来启动一下我们写的框架:

    uwsgi --http :8080 --wsgi-file main.py --callable app

    这里新增了一个配置项,

    callable
    该参数的意思是,指定应用起始函数,默认是
    application
    ,如果不是这个名称,则需要额外指定,我们定义的是
    app
    ,所以需要将其指定为
    app

    启动后,我们可以观察一下,我们之前在框架

    Routes
    函数中,我们打印了路由和函数的信息,我们可以看下
    uwsgi
    输出的信息,是有有我们定义的函数。

    发现没问题后,我们使用

    curl
    再来请求一下路由,验证是否有问题:

    如上结果,结果正确输出。

    标签: python

    热门推荐