首先来问一个问题,如何来看待Python web开发技术?如果不知道如何回答,我们换个问题:如何理解Python web的本质,这个我先用了三个程序来说明。
首先第一个是Python基于socket的编程,开放了8000端口,然后在指定端口处监听,接收到消息返回。
importsocket
defhandle_request(client):
buf= client.recv(1024)
client.send("HTTP/1.1 200 OK\r\n\r\n")
client.send("Hello, Jeanron ")
defmain():
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sock.bind(('localhost',8000))
sock.listen(5)
whileTrue:
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
fromwsgiref.simple_serverimportmake_server
defRunServer(environ,start_response):
start_response('200 OK',[('Content-Type','text/html')])
return'Hello, wsgi!'
if__name__ =='__main__':
httpd = make_server('',8000,RunServer)
print"Serving HTTP on port 8000..."
httpd.serve_forever()
但是这种方式的问题也很明显,比如有50类请求,我们在程序端如何处理,一种自然的思想就是我们需要解耦。比如是类别1,就切换到类别1 的逻辑处理,以此类推。但是这样一来,程序里就会嵌入大量的if-else块,而说实话这种方式还是比较粗放的,一点也不优雅。可以想象如果有200个不同的请求,程序有多臃肿。所以这种方式有待改进,我们可以自己手工来分离一些逻辑,形成不同的模块,不同的请求会有不同的逻辑处理和返回。
所以在这个基础上,我们需要第三个程序。
#!/usr/bin/env python
# coding:utf-8
fromwsgiref.simple_serverimportmake_server
defindex():
return'index'
deflogin():
return'login'
defrouters():
urlpatterns = (
('/index/',index),
('/login/',login),
)
returnurlpatterns
defRunServer(environ,start_response):
start_response('200 OK',[('Content-Type','text/html')])
url = environ['PATH_INFO']
print(url)
urlpatterns = routers()
func =None
foriteminurlpatterns:
ifitem[] == url:
func = item[1]
break
iffunc:
returnfunc()
else:
return'404 not found'
if__name__ =='__main__':
httpd = make_server('',8000,RunServer)
print"Serving HTTP on port 8000..."
httpd.serve_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
领取专属 10元无门槛券
私享最新 技术干货