1.web请求本质是什么:

web请求本质:就是一个socket。      浏览器充当是客户端,python充当一个服务器端
      浏览器请求相当一次tcp请求,请求完成断开连接 ,下次去的时候,还知道是谁不,
        http是无状态的。使用下之前写的socket代码:

#__author__ = 'wuchao'
import socket
def handle_request(client):
buf = client.recv(1024)
client.send(b"HTTP/1.1 200 OK\r\n\r\n")
client.send(b"Hello, Seven")
def main():
sock = socket.socket()
sock.bind(('localhost',8099))
sock.listen(5)
while True:
connection, address = sock.accept()
handle_request(connection)
connection.close()
if __name__ == '__main__':
main()

mysocket.py

运行以上程序,浏览器访问:localhost:

上述通过socket来实现了其本质,而对于真实开发中的python web程序来说,一般会分为两部分:服务器程序和应用程序。服务器程序负责对socket服务器进行封装,
    并在请求到来时,对请求的各种数据进行整理。应用程序则负责具体的逻辑处理。为了方便应用程序的开发,就出现了众多的Web框架,例如:Django、Flask、web.py 等。
    不同的框架有不同的开发方式,但是无论如何,开发出的应用程序都要和服务器程序配合,才能为用户提供服务。这样,服务器程序就需要为不同的框架提供不同的支持。
    这样混乱的局面无论对于服务器还是框架,都是不好的。对服务器来说,需要支持各种不同框架,对框架来说,只有支持它的服务器才能被开发出的应用使用。这时候,
    标准化就变得尤为重要。我们可以设立一个标准,只要服务器程序支持这个标准,框架也支持这个标准,那么他们就可以配合使用。一旦标准确定,双方各自实现。这样,
    服务器可以支持更多支持标准的框架,框架也可以使用更多支持标准的服务器。

WSGI(Web Server Gateway Interface)是一种规范,WSGI不是服务器,不是API,不是Python模块,更不是什么框架,而是一种服务器和客户端交互的接口规范

更具体的规范说明请搜索“PEP 3333”。

在WSGI规范下,web组件被分成三类:client, server, and middleware.
WSGI apps(服从该规范的应用)能够被连接起来(be stacked)处理一个request,这也就引发了中间件这个概念,中间件同时实现c端和s端的接口,c看它是上游s,s看它是下游的c。
WSGI的s端所做的工作仅仅是接收请求,传给application(做处理),然后将结果response给middleware或client.除此以外的工作都交给中间件或者application来做。
 
python标准库提供的独立WSGI服务器称为wsgiref。
 from wsgiref.simple_server import make_server

 def RunServer(environ, start_response):
start_response('200 OK', [('Content-Type', 'text/html')])
return [bytes('<h1>返回的结果</h1>', encoding='utf-8'), ]#需要返回byte类型 if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

测试案例:

from wsgiref.simple_server import make_server

def RunServer(environ, start_response):
path_info=environ['PATH_INFO'] #取得用户请求地址
start_response('200 OK', [('Content-Type', 'text/html')])
if path_info == '/':
return [bytes('<html><head><meta charset="utf-8"></head><h1>首页</h1><a href="/list.html">列表页</a></html>', encoding='utf-8'), ] # 需要返回byte类型
if path_info == '/list.html':
return [bytes('<html><head><meta charset="utf-8"><h1>列表页</h1><a href="/show.html">详细页</a></html>', encoding='utf-8'), ] # 需要返回byte类型
if path_info == '/show.html':
return [bytes('<html><head><meta charset="utf-8"><h1>详细页</h1><a href="/">返回首页</a></html>', encoding='utf-8'), ] # 需要返回byte类型
else:
return [bytes('<html><head><meta charset="utf-8"><h1>错误页面</h1><a href="/">返回首页</a></html>', encoding='utf-8'), ] # 需要返回byte类型
# for item in environ:
# print(item,':',environ[item]) if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

自定义Web框架

1.创建一个views.py 文件

 #__author__ = 'wuchao'
def hand_test():
f = open('templates/test.html', 'rb')
res = f.read()
res = res.replace(b'{{name}}', bytes('黄飞', encoding='utf8'))
return [(res), ] def hand_test1():
f = open('templates/test1.html', 'rb')
res = f.read()
return [(res), ]
def hand_js():
f = open('templates/my.js', 'rb')
res = f.read()
return [(res), ] def other():
return [bytes('<h1>404</h1>', encoding='utf-8'), ]

2.创建一个wsgi.py文件

 #__author__ = 'wuchao'
from wsgiref.simple_server import make_server
from view import *
urls={
'/test':hand_test,
'/test1':hand_test1,
'/my.js':hand_js
}
def RunServer(environ, start_response):
path_info =environ['PATH_INFO'] #取得页面参数
start_response('200 OK', [('Content-Type', 'text/html')])#必须
if path_info in urls: #判断页面参数是否在urls里存在
fun=urls[path_info]
return fun() #调用urls对应的函数
else:
return other() #如果参数不存在,则调用other函数
if __name__ == '__main__':
httpd = make_server('', 8098, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

3。创建templates模板文件夹:

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
</head>
<body>
<div style="border: 1px solid red; width: 200px;height: 200px">
{{name}}昨天晚上妹子都有约,没人理他。
</div>
</body>
</html>

第一节:web 框架本质的更多相关文章

  1. WEB框架本质和第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 总的来说:Web框架的本质就是浏览 ...

  2. 第一篇web框架

    第一篇web框架 http协议 web应用和web框架 主 文 http协议 HTTP简介 HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于从万维 ...

  3. Django框架01 / http协议、web框架本质

    Django框架01 / http协议.web框架本质 目录 Django框架01 / http协议.web框架本质 1.http协议 1.1 http协议简介 1.2 什么是http协议 1.3 H ...

  4. Python开发【第十四篇】:Web框架本质

    Web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...

  5. Web框架本质

    Web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. #!/usr/bin/env python #coding:utf- ...

  6. Python自动化运维之26、Web框架本质、MVC与MTV

    一.Web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. #!/usr/bin/env python #coding:ut ...

  7. Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  8. Web框架本质及第一个Django实例 Web框架

    Web框架本质及第一个Django实例   Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web ...

  9. Django之Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

随机推荐

  1. h5-文本框

    h5-文本框 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  2. (转)64位开源处理器Rocket的源代码简单介绍

    转载地址: http://blog.csdn.net/leishangwen/article/details/46604819 最近大概阅读了一下UCB发布的Rocket处理器的源码,对源代码各个文件 ...

  3. hdu6038 Function 函数映射

    /** 题目:hdu6038 Function 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6038 题意:给定一个a排列[0,n-1],一个b排列[0, ...

  4. 利用:header匹配所有标题做目录

    1.问题背景 查找到h1-h6,并遍历它们,打印出内容 2.实现源码 <!DOCTYPE html> <html> <head> <meta charset= ...

  5. android 开发积累

    1.ListView滚动黑屏问题 ListView滚动时,数据项变成黑色 问题解决办法:通过添加 android:cacheColorHint = "#00000000" 将背景设 ...

  6. C++ 类的多态一(virtual关键字--构造函数深刻理解)

    //virtual关键字--构造函数深刻理解 #include<iostream> using namespace std; /* C语言编译器,c++编译器全部是静态链编,就是一段一段代 ...

  7. SQL2005 第一次配置没有服务器名称的问题

    问题描述:第一次启动没有服务器名称 解决方法: 1.进入 我的电脑——属性——管理——服务 找到SQL Server 右键属性 弹出下图 找到可执行文件路径 鼠标左键拖到底部 看到 -s实例名,这里的 ...

  8. PDF解析。。。

    解析出PDF中的文字.用项目名称作Key取对应的值.. 正则匹配 .....:..\n

  9. Dependency Property 依赖属性

    依赖属性就是一种可以自己没有值,并能通过使用Binding从数据源获得值(依赖在别人身上)的属性.拥有依赖属性的对象称为“依赖对象”. WPF开发中,必须使用依赖对象作为依赖属性的宿主,使二者结合起来 ...

  10. jQuery实现的浮动层div浏览器居中显示效果

    本文实例讲述了jQuery实现的浮动层div浏览器居中显示效果.分享给大家供大家参考,具体如下: 1.在页面的head中引入jQuery <script type="text/java ...