openstack XXX

  • 时间:
  • 浏览:0
  • 来源:uu快3下载网站_uu快3开户二维码

     curl -X POST  http://localhost:5088/proj1/nex/17/types

    map.connect('name',"/{action}/{pid}",controller=a)

  map.connect('/images',controller=a,action='search',conditions={'method':['GET']}) 

   匹配条件2 

  3)map.connect 及map.resource均用来建立路由匹配条件

                           path_prefix = '{projectid}/%s/:%s_id' %('nex','nexs'))

      map.connect('/messages/{id}',controller=a,action='delete',conditions={'method':['DELETE']})

    map.resource('type', 'types',controller=other_controller,

    在路由5的条件下,再加一根绳子

      匹配nexs_id 为17,controller 为other_controller,  parent_resource的作用为形成name_prefix = 'message_',具体作用不详,有待研究

  openstack中的nova-api分析:

  参考资料:http://routes.readthedocs.org/en/latest/restful.html

  2)routes.middleware.RoutesMiddleware,将接受到的url,自动调用map.match()土最好的办法,将url进行路由匹配并将结果存入request请求的环境变量['wsgiorg.routing_args'],最都可以 调用其第有有有1个多多参数给出的函数接口,即self.dispatch。

      map.connect('/messages',controller=a,action='index',conditions={'method':['GET']})

    map.resource初始化时还可都可以了指定curl访问路径的前缀路径,如匹配条件3及4那么指定时,默认为collection_name(资源集合名)

    map.resource("message","messages",controller=a) 等同于以下匹配条件:

    member={'update_many':'POST','delete_many':'POST'}    定义了单个资源土最好的办法 update_many,其curl动作为POST,delete_many,其curl动作为POST

  匹配条件3   

      map.connect('/messages/{id}',controller=a,action='show',conditions={'method':['GET']})

                            collection_name='messages'),

分析:

      map.connect('/messages/{id}',controller=a,action='update',conditions={'method':['PUT']})

    前两条是针对整个资源集合的操作,后三条是针对资源集合中某个固定资源的操作 

                           parent_resource=dict(member_name='message',

  route 可都可以了从url提取相应的参数,如controller,action可能性其它用户买车人定义的变量

  匹配条件指定了curl的动作为GET ,访问路径为images  对应的action 为search

    collection={'search':'GET','create_many':'POST'}       定义了资源集合土最好的办法 search,其curl动作为GET,create_many,其curl动作为POST

  当url传入的id蕴含'.',会将'.'后的字符窜匹配为format,如输入的id 为 '12.hihi' ,匹配id='12', format='hihi'

    resource中的controller对象的类定义都可以要有__call__,要不然,匹配后变为type(controller)为unicode,是因为不明,有待研究

  这里匹配结果中的id为某个具体资源id,这里乱取,后三条curl针对具体资源(id为12)的操作,前两条是针对整个资源集合的操作

  匹配条件4

    匹配条件那么指定curl的动作,随后 所有的动作(PUT,POST,GET,。。)都匹配,第八个curl请求,匹配的action 为failfunc,pid为test,随后 守护进程那么定义failfunc函数,报错

  匹配条件5 

    map.resource('message', 'messages',controller=a,path_prefix='/{projectid}',

                    collection={'list_many':'GET','create_many':'POST'},

                    member={'update_many':'POST','delete_many':'POST'})

  1)webob.dec.wsgify是webob为WSGI应用守护进程提供的有有有1个多多装饰器,作用是将有有有1个多多函数转再加有有有1个多多WSGI应用。

    参考资料 http://tumblr.wachang.NET/post/38149417931/Python-paste-webob-3

    map.resource('message', 'messages',controller=a,

                        collection={'search':'GET','create_many':'POST'},

                        member={'update_many':'POST','delete_many':'POST'})

    参考资料   http://blog.csdn.Net/networm3/article/details/866650

      map.connect('/messages',controller=a,action='create',conditions={'method':['POST']})

    指定path_prefix后,路径为path_prefix/collection_name

    map.resource除了默认的路由条件外,还可都可以了额外的定义‘资源集合的土最好的办法’以及‘单个资源的土最好的办法’

  大问题:

  api服务是入口,主要把client端发送http请求映射到具体处理函数上,主要涉及有有有1个多多模块:

    collection_name作为访问的路径名,且当那么传入参数controller时,controller=collection_name

  针对守护进程中的匹配条件1  

    map.resource("message","messages",controller=a)  ,map.resource组织组织结构定义了默认的匹配条件

    第有有有1个多多参数message为 member_name(资源名),第八个参数messages为collection_name(资源集合名),一般定义资源集合名为资源名的复数,我这里随便取名