Python培训
400-996-5531
首先来问一个问题,如何来看待Python web开发技术?如果不知道如何回答,我们换个问题:如何理解Python web的本质,这个我先用了三个程序来说明。
首先第一个是Python基于socket的编程,开放了8000端口,然后在指定端口处监听,接收到消息返回。
import socket def handle_request(client): buf = client.recv(1024) client.send("HTTP/1.1 200 OK\r\n\r\n") client.send("Hello, Jeanron ") def main(): sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.bind(('localhost', 8000)) sock.listen(5) while True: connection, address = sock.accept() handle_request(connection) connection.close() if __name__ == '__main__': main()
这可以算是一个最基础的通信程序,而这里还没有牵扯到web方向的内容,有一个最基本的点就是这种方式没有任何的规范和要求,行则必达。而一说到web端,必然是和html挂钩的。对于处理web应用和web服务器的请求,必然要提到wsgi,这个和Java里面是类似的,在Java里面这种服务端的软件组件技术,叫做Servlet,其实它的定位就是轻巧的小玩意(lite),比如Java里面的applet也是类似的命名。Servlet能够动态的扩展web服务器的功能,简单来说,就是在Http服务器上提供了一个扩展的接口,是一个接口标注。我们简单扩展下。
按照JavaEE的规范,任何servlet都需要直接或间接的实现Servlet接口,即javax.servlet.Servlet,这个接口里面只定义了5个方法
因为servlet是协议无关的,要直接实现还是很困难的,所以,曾经的sun给除了实现Servlet接口的类,是javax.servlet.GenericServlet类。
这个通用的类只能是一个抽象类,里面的核心方法是service(),所以由此可以看出,它还是协议无关,依旧和协议无关,所以就有了新的实现类HttpServlet,我们写web应用的时候只需要重点关注如何重写get和post方法即可。原来是从安全和扩展性上更倾向于post方法,但是目前get方法更流行一些。
所以明白了上面的一些内容,再来看Python就会明确很多。
python标准库提供的独立WSGI服务器称为wsgiref
WSGI(Web Server Gateway Interface)是一种规范,它定义了使用python编写的web app与web server之间接口格式,实现web app与web server间的解耦,Python默认封装了一个版本,所以我们可以很容易的开启一个simple_server来。
这样一来代码就有了基本的规范和标准,算得上是一个标准的web开端的姿势。还可以在这个基础上嵌入html标签,这样前端显示就会很丰富了。
#!/usr/bin/env python #coding:utf-8 from wsgiref.simple_server import make_server def RunServer(environ, start_response): start_response('200 OK', [('Content-Type', 'text/html')]) return '<h1>Hello, wsgi!</h1>' if __name__ == '__main__': httpd = make_server('', 8000, RunServer) print "Serving HTTP on port 8000..." #_forever()
但是这种方式的问题也很明显,比如有50类请求,我们在程序端如何处理,一种自然的思想就是我们需要解耦。比如是类别1,就切换到类别1 的逻辑处理,以此类推。但是这样一来,程序里就会嵌入大量的if-else块,而说实话这种方式还是比较粗放的,一点也不优雅。可以想象如果有200个不同的请求,程序有多臃肿。所以这种方式有待改进,我们可以自己手工来分离一些逻辑,形成不同的模块,不同的请求会有不同的逻辑处理和返回。
所以在这个基础上,我们需要第三个程序。
#!/usr/bin/env python # coding:utf-8 from wsgiref.simple_server import make_server def index(): return 'index' def login(): return 'login' def routers(): urlpatterns = ( ('/index/', index), ('/login/', login), ) return urlpatterns def RunServer(environ, start_response): start_response('200 OK', [('Content-Type', 'text/html')]) url = environ['PATH_INFO'] print(url) urlpatterns = routers() func = None for item in urlpatterns: if item[0] == url: func = item[1] break if func: return func() else: return '404 not found' if __name__ == '__main__': httpd = make_server('', 8000, RunServer) print "Serving HTTP on port 8000..." #_forever()
这里定义了一个路由转发的角色,负责处理请求的跳转和返回。如果自己再进一层抽象一下,其实也是可以的。
所以到目前为止,我们有了一个基本的认识,那就是还没有使用任何的web框架,但是已经能够处理基本的需求了。
使用框架只是一些具体功能的抽象,能够提高我们开发的效率,就跟我们使用记事本还是IDE开发是类似的。
当然这个时候,web的返回还是一些比较基础的内容,我们如果需要丰富的内容,比如数据放如表格,动态菜单等等。就需要做一系列额外的补充工作了。
Python web的一个基本的图形表示如下:
客户端请求都会通过url的筛选,走入不同的逻辑处理,即不同的函数。
这一点和Java栈的web处理略有不同。
所以前端技术就是这样层出不穷。我简单列了一些技术框架和方向。
后端(基于Python):
Django,Tornado,web.py,Flask,
Bottle,CherryPy,Quixote
前端:
Javascript框架
Angular.Js, React,JQuery
Vue.js, , Node.Js,
前端UI框架
bootstrap
Pure,EasyUI,AmazeUI,SB-admin 2
前端可视化
echarts,tableau
本文内容转载自网络,本着传播与分享的原则,来源/作者信息已在文章顶部表明,版权归原作者所有,如有侵权请联系我们进行删除!
填写下面表单即可预约申请免费试听! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!
Copyright © 京ICP备08000853号-56 京公网安备 11010802029508号 达内时代科技集团有限公司 版权所有
Tedu.cn All Rights Reserved