wigs的理解和应用

1、

首先了解下,Web应用的本质,大体如下:

1、浏览器发送一个HTTP请求;

2、服务器收到请求,生成一个HTML文档;

3、服务器把HTML文档作为HTTP响应的Body发送给浏览器;

4、浏览器收到HTTP响应,从HTTP Body取出HTML文档并显示。

以上这些操作一般都有现成的HTTP服务器软件,接收用户请求,从文件中读取HTML,返回。
如,Apache、Nginx、Lighttpd等这些常见的静态服务器就是干这件事情的。
整个过程接受HTTP请求、解析HTTP请求、发送HTTP响应都有这些服务器来完成,不过前提
是这些页面都是现成生成好的html静态页面。

2、

如果要动态生成HTML,就需要把上述步骤自己来实现。正确的做法是底层代码由专门的服务
器软件实现,我们用Python专注于生成HTML文档。因为我们不希望接触到TCP连接、HTTP
原始请求和响应格式,所以,需要一个统一的接口,让我们专心用Python编写Web业务(引用网上描述)

接口WSGI(Web Server Gateway Interface),就实现了这些功能,他的定义非常简单,只需要
Web开发者实现一个函数,就可以响应HTTP请求。

如:

1 def application(environ, start_response):
2     start_response(‘200 OK‘, [(‘Content-Type‘, ‘text/html‘)])
3     return ‘<h1>Hello, world!</h1>‘

environ:一个包含所有HTTP请求信息的dict对象。

start_response:一个发送HTTP响应的函数。

有了WSGI,我们关心的就是如何从environ这个dict对象拿到HTTP请求信息,然后构造HTML,通过start_response()发送Header,最后返回Body。

整个application()函数本身没有涉及到任何解析HTTP的部分,也就是说,底层代码不需要我们自己编写,我们只负责在更高层次上考虑如何响应请求就可以了。

我们现在用Python内置的WSGI服务器,这个模块叫wsgiref 来验证下整个过程。

def application(environ, start_response):
    start_response(‘200 OK‘, [(‘Content-Type‘, ‘text/html‘)])
    return ‘<h1>Hello, world!</h1>‘

from wsgiref.simple_server import make_server
# 创建一个服务器,IP地址为空,端口是8000,处理函数是application:
httpd = make_server(‘‘, 8000, application)
print "Serving HTTP on port 8000..."
# 开始监听HTTP请求:
httpd.serve_forever()

启动成功后,打开浏览器,输入http://localhost:8000/,就可以看到结果了。

3、不过一般实际应用中会稍微加工,这样更符合面向对象的原则。

请看以下实例:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author:Eric.yue

from wsgiref.simple_server import make_server
class WSGIapp(object):
    def __init__(self):
        self.path_info = {}

    def route(self,path=None):
        def wrapper(application):
            self.path_info[path] = application
        return wrapper

    def __call__(self,environ,start_response):
        path = environ[‘PATH_INFO‘]
        if path in self.path_info:
            status = ‘200 OK‘
            response_headers = [(‘Content-Type‘,‘text/plain‘)]
            start_response(status,response_headers)
            return self.path_info[path]()
        else:
            status = ‘404 Not Found‘
            response_headers = [(‘Content-Type‘,‘text/plain‘)]
            start_response(status,response_headers)
            return ‘404 Not Found!‘

app = WSGIapp()

@app.route(‘/‘) #register router
def index():
    return [‘index‘]

@app.route(‘/hello‘) #register router
def hello():
    return [‘hello world‘]

‘‘‘
app 为函数,这里__call__的作用就是把类实例当做一个函数来执行
有时候为了加入权限需要再执行一层middleware
middleware 中间件是一类特殊的程序,可以在容器和应用之间干一些事
‘‘‘

class Auth(object):
    def __init__(self,app):
        self.app = app

    def __call__(self,environ, start_response):
        #TODO something
        return self.app(environ, start_response)

Auth_app = Auth(app)
httpd = make_server(‘‘,8888,Auth_app)
httpd.serve_forever()

OVER!

时间: 2024-12-07 14:55:51

wigs的理解和应用的相关文章

Python——深入理解urllib、urllib2及requests(requests不建议使用?)

深入理解urllib.urllib2及requests            python Python 是一种面向对象.解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年,Python 源代码同样遵循 GPL(GNU General Public License)协议[1] .Python语法简洁而清晰,具有丰富和强大的类库. urllib and urllib2 区别 urllib和urllib2模块都做与请求URL相关的操作,但

关于SVM数学细节逻辑的个人理解(三) :SMO算法理解

第三部分:SMO算法的个人理解 接下来的这部分我觉得是最难理解的?而且计算也是最难得,就是SMO算法. SMO算法就是帮助我们求解: s.t.   这个优化问题的. 虽然这个优化问题只剩下了α这一个变量,但是别忘了α是一个向量,有m个αi等着我们去优化,所以还是很麻烦,所以大神提出了SMO算法来解决这个优化问题. 关于SMO最好的资料还是论文<Sequential Minimal Optimization A Fast Algorithm for Training Support Vector

2.2 logistic回归损失函数(非常重要,深入理解)

上一节当中,为了能够训练logistic回归模型的参数w和b,需要定义一个成本函数 使用logistic回归训练的成本函数 为了让模型通过学习来调整参数,要给出一个含有m和训练样本的训练集 很自然的,希望通过训练集找到参数w和b,来得到自己得输出 对训练集当中的值进行预测,将他写成y^(I)我们希望他会接近于训练集当中的y^(i)的数值 现在来看一下损失函数或者叫做误差函数 他们可以用来衡量算法的运行情况 可以定义损失函数为y^和y的差,或者他们差的平方的一半,结果表明你可能这样做,但是实际当中

理解信息管理系统

1.信息与数据的区别是什么? 数据是记录客观事物,可鉴别的符号,而信息是具有关联性和目的性的结构化,组织化的数据.数据经过处理仍是数据,而信息经过加工可以形成知识.处理数据是为了便于更好的解释,只有经过解释,数据才有意义,才可以成为信息.可以说信息是经过加工以后,对客观世界产生影响的数据. 2.信息与知识的区别是什么? 信息是具有关联性和目的性的结构化,组织化的数据,知识是对信息的进一步加工和应用,是对事物内在规律和原理的认识.信息经过加工可以形成知识. 3.举一个同一主题不同级别的数据.信息.

深度理解div+css布局嵌套盒子

1. 网页布局概述 网页布局的概念是把即将出现在网页中的所有元素进行定位,而CSS网页排版技术有别于传统的网页排版方法,它将页面首先在整体上使用<div>标记进行分块,然后对每个快进行CSS定位以及设置显示效果,最后在每个块中添加相应的内容.利用CSS排版方法更容易地控制页面每个元素的效果,更新也更容易,甚至页面的拓扑结构也可以通过修改相应的CSS属性来重新定位.  2. 盒子模型 盒子模型是CSS控制页面元素的一个重要概念,只有掌握了盒子模型,才能让CSS很好地控制页面上每一个元素,达到我们

深入理解Java:类加载机制及反射

一.Java类加载机制 1.概述 Class文件由类装载器装载后,在JVM中将形成一份描述Class结构的元信息对象,通过该元信息对象可以获知Class的结构信息:如构造函数,属性和方法等,Java允许用户借由这个Class相关的元信息对象间接调用Class对象的功能. 虚拟机把描述类的数据从class文件加载到内存,并对数据进行校验,转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是虚拟机的类加载机制. 2.工作机制 类装载器就是寻找类的字节码文件,并构造出类在JVM内部表示

八幅漫画理解使用 JSON Web Token 设计单点登录系统

原文出处: John Wu 上次在<JSON Web Token – 在Web应用间安全地传递信息>中我提到了JSON Web Token可以用来设计单点登录系统.我尝试用八幅漫画先让大家理解如何设计正常的用户认证系统,然后再延伸到单点登录系统. 如果还没有阅读<JSON Web Token – 在Web应用间安全地传递信息>,我强烈建议你花十分钟阅读它,理解JWT的生成过程和原理. 用户认证八步走 所谓用户认证(Authentication),就是让用户登录,并且在接下来的一段时

谈谈你对Hibernate的理解

答: 1. 面向对象设计的软件内部运行过程可以理解成就是在不断创建各种新对象.建立对象之间的关系,调用对象的方法来改变各个对象的状态和对象消亡的过程,不管程序运行的过程和操作怎么样,本质上都是要得到一个结果,程序上一个时刻和下一个时刻的运行结果的差异就表现在内存中的对象状态发生了变化. 2.为了在关机和内存空间不够的状况下,保持程序的运行状态,需要将内存中的对象状态保存到持久化设备和从持久化设备中恢复出对象的状态,通常都是保存到关系数据库来保存大量对象信息.从Java程序的运行功能上来讲,保存对

IOS contentOffset该如何理解

contentOffset是哪个点??? 首先从字面理解:内容偏移 我可是查了词典的!!! 对于contentOffset有的时候我们会产生错误理解. 我不想在这里介绍错误的理解避免不必要的混淆. 我们什么时候会遇到contentOffset??? 更多的时候是在滚动试图中,我们可以通过它结合代理实现一些方法. 比如轮播(我会在下一篇介绍轮播的实现原理至于代码如果需要我可整理出来) 那么请让我通过图片演示来解释contentOffset. (一) 图一中绿色为屏幕也就是最大的显示范围也是滚动视图