如果理解Python web开发技术

首先来问一个问题,如何来看待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

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180204B0091R00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券