前言
CherryPy是Python的一个Web框架,通过MethodDispatcher内建了对REST的支持,而且使用非常方便。
示例
首先,我们需要有一个符合REST风格的资源(Resource)。通过Python对象来定义:
import cherrypy class ProgSnaps(object): exposed=True def GET(self): return "You access the REST api /ProgSap/GET"
接着,将配置里默认的Dispatcher修改为支持REST的MethodDispatcher:
conf = {'/':{'request.dispatch':cherrypy.dispatch.MethodDispatcher()} }
最后,为CherryPy添加到资源的映射,启动服务器就可以通过url:http://localhost:8080/api/ProgSnaps 来访问了。
cherrypy.tree.mount(ProgSnaps(),"/api/ProgSnaps",conf)
注意事项
- 作为资源的Python对象必须是整个对象都exposed,通过设置一个对象的属性来实现,比如在ProgSnaps中设定exposed=true。非REST的情况下,都是在要暴露的方法上面添加@cherrypy.expose属性。
- REST的方法名必须都是大写的,比如GET,PUT,POST和DELETE。其它非大写的方法也可以定义在资源对象中,但是无法通过url访问到,可以作为实现REST方法(GET等)的辅助方法存在。比如例子中的getContent方法。
- 不需要自己定义http的allow头信息了,CherryPy根据资源对象中暴露的REST方法自动生成。比如本例中我们在ProgSnaps中定义了GET和PUT,那么最后http的头中会有这样的信息:
Allow:GET, HEAD, UPDATE
注:HEAD是默认添加的。REST总是允许访问HEAD信息。
完整代码
import cherrypy class ProgSnaps(object): exposed=True def GET(self): #return "You access the REST api /ProgSap/GET" return self.getContent("GET") def UPDATE(self): return "You have accessed the REST api /ProgSap/UPDATE" def getContent(self,method): return "You access the REST api /ProgSap/"+method conf = { '/':{'request.dispatch':cherrypy.dispatch.MethodDispatcher()} } if __name__ == '__main__': cherrypy.tree.mount(ProgSnaps(),"/api/ProgSnaps",conf) cherrypy.engine.start() cherrypy.engine.block()