设计
RESTful API时要注意的一点是GET和POST的合并,就好像它们是同一件事一样。使用Django的基于函数的视图和
CherryPy的默认调度程序很容易犯此错误,尽管这两个框架现在都提供了解决此问题的方法(分别基于类的视图和
MethodDispatcher)。
HTTP动词在REST 中非常重要,除非对此非常小心,否则最终会陷入REST反模式。
一些正确的框架是
web.py,
Flask和
Bottle。当与
mimerender库结合使用时(充分披露:我写了它),它们使你可以编写漂亮的RESTful Web服务:
import webimport jsonfrom mimerender import mimerenderrender_xml = lambda message: '<message>%s</message>'%messagerender_json = lambda **args: json.dumps(args)render_html = lambda message: '<html><body>%s</body></html>'%messagerender_txt = lambda message: messageurls = ( '/(.*)', 'greet')app = web.application(urls, globals())class greet: @mimerender( default = 'html', html = render_html, xml = render_xml, json = render_json, txt = render_txt ) def GET(self, name): if not name: name = 'world' return {'message': 'Hello, ' + name + '!'}if __name__ == "__main__": app.run()该服务的逻辑仅实现一次,并且正确的表示选择(Accept标头)+分配给正确的呈现函数(或模板)的操作是整洁,透明的。
$ curl localhost:8080/x<html><body>Hello, x!</body></html>$ curl -H "Accept: application/html" localhost:8080/x<html><body>Hello, x!</body></html>$ curl -H "Accept: application/xml" localhost:8080/x<message>Hello, x!</message>$ curl -H "Accept: application/json" localhost:8080/x{'message':'Hello, x!'}$ curl -H "Accept: text/plain" localhost:8080/xHello, x!添加了有关Django基于类的视图,
CherryPy的
MethodDispatcher和
Flask and Bottle框架的信息。提出问题时,两者都不存在。


![对Python REST(Web服务)框架的建议?[关闭] 对Python REST(Web服务)框架的建议?[关闭]](http://www.mshxw.com/aiimages/31/596773.png)
