1. web请求的本质就是一个socket。

2.http:一次请求,一次响应,断开链接。如下程序:必须先运行服务器端,然后客户端才能去连接。所有web框架的本质就是如下:

import socket

def handle_request(client):
but = client.recv(1024)
client.send(bytes('Http/1.1 200 OK\r\n\r\n', encoding='utf-8'))
client.send(bytes('Hello Seven', encoding='utf-8')) def main():
sock = socket.socket()
sock.bind(('localhost', 8000))
sock.listen(5)
while True:
conn, addr = sock.accept()
handle_request(conn)
conn.close() if __name__ == '__main__':
main()

必须先运行服务器端,然后客户端才能去连接。必须先运行服务器端,然后客户端才能去连接。必须先运行服务器端,然后客户端才能去连接。重要的事说三遍,否则会报错。

3.wsgiref 模块就封装了server-client的功能。

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

WSGI(Web Server Gateway Interface)是一种规范,它定义了使用python编写的web app与web server之间接口格式,实现web app与web server间的解耦。

python标准库提供的独立WSGI服务器称为wsgiref。

from wsgiref.simple_server import make_server

def RunServer(environ, start_response):

  #environ 封装了客户发来的所有数据
#start_response 封装了要返回给用户的数据,响应头状态。
start_response('200 OK', [('Content-Type', 'text/html')])
#返回的内容
return [bytes('<h1>Hello, web!</h1>', encoding='utf-8'), ] if __name__ == '__main__':
httpd = make_server('', 8000, RunServer) print("Serving HTTP on port 8000...") httpd.serve_forever()

效果:

4. 插播字符串转字节的3种方式。Python2里面有unicode, python3里面有bytes.

#字符串变字节的3种方式
# b'ffff'
# bytes('ffff',encoding='utf-8')
# 'fffff'.encode('utf-8') import hashlib
m=hashlib.md5()
m.update(b'ffff')
ret=m.hexdigest()
print(ret)

5. 统一资源定位器(URL)指的是Internet文件在网上的地址。好比一个街道在城市地理上的地址。通俗点讲URL就是你的IE地址栏上的那串字符 。针对客户不同的URL,服务器端应该返回不同的内容。

如果URL=index,则返回index;如果URL=date,则返回date;否则返回404

from wsgiref.simple_server import make_server

def handle_index():
return [bytes('<h1>Hello, Index!</h1>', encoding='utf-8'), ] def handle_date():
return [bytes('<h1>Hello, Date!</h1>', encoding='utf-8'), ] def RunServer(environ, start_response):
#environ 客户端发来的所有数据
#start_response 封装要返回给用户的数据,响应头状态
start_response('200 OK', [('Content-Type', 'text/html')])
current_url=environ['PATH_INFO']
if current_url=='/index':
return handle_index()
elif current_url=='/date':
return handle_date()
else:
return [bytes('<h1>404!</h1>', encoding='utf-8'), ] if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

先启动服务器端,然后测试运行效果:

6. 一个一个写太麻烦了。在Python中,会把所有的URL都放到一个列表里面。运行结果同上。

from wsgiref.simple_server import make_server

def handle_index():
return [bytes('<h1>Hello, Index!</h1>', encoding='utf-8'), ] def handle_date():
return [bytes('<h1>Hello, Date!</h1>', encoding='utf-8'), ] URL_DICT={
"/index":handle_index,
"/date":handle_date,
} def RunServer(environ, start_response):
#environ 客户端发来的所有数据
#start_response 封装要返回给用户的数据,响应头状态
start_response('200 OK', [('Content-Type', 'text/html')])
current_url=environ['PATH_INFO']
func=None
if current_url in URL_DICT:
func=URL_DICT[current_url]
if func:
return func()
else:
return [bytes('<h1>404!</h1>', encoding='utf-8'), ] if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

7. 把1类写成1个函数,这样可以省略代码。

8. 也可以把要返回的内容写到一个文件里面。如下图:新建一个index.html文件,内容如下:

修改程序:

from wsgiref.simple_server import make_server

def handle_index():
f=open('index.html','rb')
data=f.read()
f.close()
return [data,] def handle_date():
return [bytes('<h1>Hello, Date!</h1>', encoding='utf-8'), ] URL_DICT={
"/index":handle_index,
"/date":handle_date,
} def RunServer(environ, start_response):
#environ 客户端发来的所有数据
#start_response 封装要返回给用户的数据,响应头状态
start_response('200 OK', [('Content-Type', 'text/html')])
current_url=environ['PATH_INFO']
func=None
if current_url in URL_DICT:
func=URL_DICT[current_url]
if func:
return func()
else:
return [bytes('<h1>404!</h1>', encoding='utf-8'), ] if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

运行结果:

9. 为了整洁,可以把所有的html都放到一个文件夹下。

10. 再建立一个文件夹Controller,把所有的业务代码都放进去。

相应的调用方式修改为:

主函数里面的代码:

from wsgiref.simple_server import make_server
from Controller import account
URL_DICT={
"/index":account.handle_index,
"/date":account.handle_date,
} def RunServer(environ, start_response):
#environ 客户端发来的所有数据
#start_response 封装要返回给用户的数据,响应头状态
start_response('200 OK', [('Content-Type', 'text/html')])
current_url=environ['PATH_INFO']
func=None
if current_url in URL_DICT:
func=URL_DICT[current_url]
if func:
return func()
else:
return [bytes('<h1>404!</h1>', encoding='utf-8'), ] if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

account函数里面的代码:

def handle_index():
f=open('View/index.html','rb')
data=f.read()
f.close()
return [data,] def handle_date():
return [bytes('<h1>Hello, Date!</h1>', encoding='utf-8'), ]

把模板放到了一个文件夹里面,把处理请求的函数放到了另外一个文件夹里面。

11. 处理请求的函数里面的内容,可以跟数据库进行替换。

主程序不变:

from wsgiref.simple_server import make_server
from Controller import account
URL_DICT={
"/index":account.handle_index,
"/date":account.handle_date,
} def RunServer(environ, start_response):
#environ 客户端发来的所有数据
#start_response 封装要返回给用户的数据,响应头状态
start_response('200 OK', [('Content-Type', 'text/html')])
current_url=environ['PATH_INFO']
func=None
if current_url in URL_DICT:
func=URL_DICT[current_url]
if func:
return func()
else:
return [bytes('<h1>404!</h1>', encoding='utf-8'), ] if __name__ == '__main__':
httpd = make_server('', 8000, RunServer)
print("Serving HTTP on port 8000...")
httpd.serve_forever()

处理请求的函数修改为:

def handle_index():
f=open('View/index.html','rb')
data=f.read()
f.close()
data=data.replace(b'@123','今天天气好晴朗'.encode('utf-8'))
return [data,] def handle_date():
return [bytes('<h1>Hello, Date!</h1>', encoding='utf-8'), ]

运行效果:

12. 类似于每次访问数据库,都可以从数据库中拿到不同的数据。下面以time为例,将处理请求的函数修改如下:

def handle_index():
import time
v=str(time.time()) f=open('View/index.html','rb')
data=f.read()
f.close()
data=data.replace(b'@123',v.encode('utf-8'))
return [data,] def handle_date():
return [bytes('<h1>Hello, Date!</h1>', encoding='utf-8'), ]

运行结果:

13. 为了规整,把数据库都放到另外一个文件夹下面。命名为model.

本节笔记:MVC与MTV的区别在仅仅于文件名的不同。上述例子是基于MVC创建的,只要把文件名一改,就成为了MTV的框架格式了。

3.WEB框架

	MVC
Model View Controller
数据库 模板文件 业务处理 MTV
Model Template View
数据库 模板文件 业务处理 ###########################WEB:MVC,MTV

web框架引入的更多相关文章

  1. Web框架的引入

    为什么会有web框架 有了上一篇内容,静态.动态web服务器的实现,已经掌握了客户端请求到服务器处理的机制.在动态资源处理中,根据请求 .py 导入模块应用,然后调用应用入口程序实现动态处理.但是在真 ...

  2. Python之Web框架Django

    Python之Web框架: Django 一. Django Django是一个卓越的新一代Web框架 Django的处理流程 1. 下载地址  Python 下载地址:https://www.pyt ...

  3. Spring 5 新特性:函数式Web框架

    举例 我们先从示例应用程序的一些摘录开始.下面是暴露Person对象的响应信息库.很类似于传统的,非响应信息库,只不过它返回Flux<Person>而传统的返回List<Person ...

  4. 关于Python的web框架

    uliwebhttp://git.oschina.net/limodou/uliweb uliweb 吸取了其他框架的经验,集成了orm.总的来说一般.这个安装后有个exe文件,命令行工具.不绿色.个 ...

  5. python_way day17 html-day3 前端插件(fontawsome,easyui,bootstrap,jqueryui,bxslider,jquerylazyload),web框架

    python_way day17 一.模板插件 图标的插件 fontawsome: 后台管理: easyui jqueryui 很多网站都会用: bootstrap :引入jQuery:(2.x,1. ...

  6. Day17 表单验证、滚动菜单、WEB框架

    一.表单验证的两种实现方式 1.DOM绑定 <!DOCTYPE html> <html lang="en"> <head> <meta c ...

  7. Python开发【第二十二篇】:Web框架之Django【进阶】

    Python开发[第二十二篇]:Web框架之Django[进阶]   猛击这里:http://www.cnblogs.com/wupeiqi/articles/5246483.html 博客园 首页 ...

  8. python运维开发(十七)----jQuery续(示例)web框架django

    内容目录: jQuery示例 前端插件 web框架 Django框架 jQuery示例 dom事件绑定,dom绑定在form表单提交按钮地方都会绑定一个onclick事件,所有查看网站的人都能看到代码 ...

  9. Python超级明星WEB框架Flask

    Flask简介 Flask是一个相对于Django而言轻量级的Web框架. 和Django大包大揽不同,Flask建立于一系列的开源软件包之上,这其中 最主要的是WSGI应用开发库Werkzeug和模 ...

随机推荐

  1. day 10 字典dict

    添加 xxx[新的key] = value 删除 del xx[key] 修改 xxx[已存在的key] = new_value 查询 xxx.get(key) 1. dict 字典 #### lis ...

  2. 【LG5055】可持久化文艺平衡树

    [LG5055]可持久化文艺平衡树 题面 洛谷 题解 终于不可以用\(Trie\)水了... 和普通的\(FHQ\;treap\)差不多 注意一下\(pushdown\).\(split\)要新开节点 ...

  3. LAUNCHXL-28379D入门学习-第一篇

    1. 首先安装controlSUITE或者C2000ware软件,TI官网下载,安装后包括C2000的函数库和例程之类的,还可以和CCS搭配使用.controlSUITE安装完之后大约4个G,所以我安 ...

  4. idea里绝对不要直接复制文件到项目中的另一处

    否则那样会将使用被复制文件的那些地方 文件名会变成复制后的那个 而路径是原来的 所以会导致找不到文件 所以绝对不要直接复制文件或者包或者目录到项目中的另一处 需要时应该新建文件 把代码复制进去 这种事 ...

  5. 二、Django用户认证之cookie和session

    1.cookie原理 Cookie意为“甜饼”,是由W3C组织提出,最早由Netscape社区发展的一种机制.目前Cookie已经成为标准,所有的主流浏览器如IE.Netscape.Firefox.O ...

  6. 说说ejabberd 离线消息的坑

    使用过ejabberd的或许知道,也许踩过这个坑.那么就说说我们踩过的ejabberd的离线消息的坑吧. ejabberd原生的离线消息的机制是,一般用户保存100条离线消息,管理员保存5000条离线 ...

  7. Jenkins CLI 通过ssh方式链接时的证书

    在Jenkins自己的配置文档下,并没有详细说明要如何生成ssh证书,不过随便网上查一查就会有很多. 这里记录一个坑: 这个ssh必须要用ssh2!!! 这个ssh必须要用ssh2!!! 这个ssh必 ...

  8. Maven学习(三)-----Maven本地资源库

    Maven本地资源库 Maven的本地资源库是用来存储所有项目的依赖关系(插件jar和其他文件,这些文件被Maven下载)到本地文件夹.很简单,当你建立一个Maven项目,所有相关文件将被存储在你的M ...

  9. JavaWeb(十三)——使用Session防止表单重复提交

    在平时开发中,如果网速比较慢的情况下,用户提交表单后,发现服务器半天都没有响应,那么用户可能会以为是自己没有提交表单,就会再点击提交按钮重复提交表单,我们在开发中必须防止表单重复提交. 一.表单重复提 ...

  10. python的pip升级问题

    近来由于pip升级为10.0.1了,导致使用pip命令报错,使用过很多方法,最终找到一种相对靠谱的方法,一下是步骤: 进入https://pypi.python.org/pypi/pip 下载pip- ...