WSGI接口

一、

所谓WSGI接口就是用户自定义的函数,以实现生成HTML文档作为HTTP请求的响应Body。

其实一个Web App,就是写一个WSGI的处理函数,针对每个HTTP请求进行响应。

用户自定义处理函数:

# -*- coding:utf-8 -*-

'''
用户自主编写的方法,专注于生成HTML文档作为HTTP请求的响应Body
HTTP响应的Body==HTML文档(服务器响应浏览器请求)
底层代码(接受HTTP请求、解析HTTP请求、发送HTTP响应)不需要我们自己编写,我们只负责在更高层次上考虑如何响应请求就可以了。
'''

#application函数做了两件事(响应HTTP请求):1)发送HTTP响应码和一组HTTP Header
#										 2)发送HTML文档作为HTTP请求的响应Body
#environ:一个包含所有HTTP请求信息的dict对象
def application(environ,start_response):
	start_response('200 ok',[('Content-Type','text/html')])
	#start_response()函数是一个发送HTTP响应的函数,接收两个参数
	#一个是HTTP响应码,一个是用list表示的一组HTTP Header,每个Header用一个包含两个str的tuple表示。
	return '<h1>hello,web!</h1>'

WSGI服务器:

# -*- coding:utf-8 -*-

'''
WSGI服务器
实现诸如:接受HTTP请求、解析HTTP请求、发送HTTP响应 等底层代码
与用户自主编写的函数进行交互,从而实现上述底层的活。
	服务器接受并解析HTTP请求,作为envion变量,调用用户函数。用户函数接受并使用envion变量
	用户函数返回的HTTP响应Body和start_response由服务器处理,发送到浏览器端
	
'''
#从自己编写的helloweb模块导入application函数(方法)
from helloweb import application
from wsgiref.simple_server import make_server

#创建一个服务窗
#IP地址为空(也可以是回送地址),端口号自定义(但不能用系统端口),处理函数是application
#则IP和端口号都是服务器端的(如百度、新浪等),当我们有http请求时,就要在浏览器中输入服务器端的IP和端口号,服务器在此端口上随时监听,有请求则调用用户的函数
httpd=make_server('127.0.0.1',8000,application)

print 'server http on port 8000'

#用创建的服务窗监听http请求(监听是否有主机访问127.0.0.1:8000)
#如果有请求,会自动调用application函数
httpd.serve_forever()

在浏览器中输入 http://localhost:8000/ http://127.0.0.1:8000/ ,WSGI服务器会调用application函数,产生如下效果:

1)HTTP响应码和HTTP Header:


2)return的HTML文档:



二、

# -*- coding:utf-8 -*-

#有了框架,我们就可以专注于用一个函数处理一个URL,而不费力去写WSGI处理函数
#至于URL到函数的映射,就交给Web框架来做。

#Flask通过Python的装饰器在内部自动地把URL和函数给关联起来
from flask import Flask
from flask import request

app = Flask(__name__)

@app.route('/', methods=['GET', 'POST'])
def home():
    return '<h1>Home</h1>'

@app.route('/signin', methods=['GET'])   #get请求仅仅是获得了登录界面的html,浏览器解析成登陆界面(显示出一个空白表单)
def signin_form():
    return '''<form action="/signin" method="post">  #需要服务器端发送数据,所以用post
              <p><input name="username"></p>
              <p><input name="password" type="password"></p>
              <p><button type="submit">Sign In</button></p>
              </form>'''

@app.route('/signin', methods=['POST'])  #这是按下submit button(Sign In)之后的行为,客户端利用POST请求向服务器发送表单数据,服务器端利用request.form从用户发送来的表单中获取用户输入信息,与服务器端数据库里的信息进行比对,如果配对成功,就返回登陆成功的HTML文档,否则返回登陆失败的HTML文档。
def signin():
    # 需要从request对象读取表单内容:
    if request.form['username']=='admin' and request.form['password']=='password':
        return '<h3>Hello, admin!</h3>'
    return '<h3>Bad username or password.</h3>'

if __name__ == '__main__':
    app.run()
特别注意,最后一个处理函数是按下submit button(Sign In)之后的行为:客户端浏览器利用POST请求向服务器端发送表单数据,服务器端利用request.form从用户发送来的请求的表单中获取用户输入信息(POST请求会把表单数据同请求一起发送给服务器),与服务器端数据库里的信息进行比对,如果配对成功,就返回登陆signin成功的HTML文档,否则返回登陆失败的HTML文档。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值