0

URL 在以下示例中被覆盖,以便我可以传递类似 http://localhost:8000/api/v1/entry/1234/1233/?format=json的内容,这样做会将参数传递给 WRAP VIEW,当我做 self.create_response(request, data),浏览器只显示类似

0x2e27a50 处的 api.Entry 对象

在浏览器中,字段不会被序列化: 注意:在这个阶段我不需要 ModelResource。如何使自定义视图 dispatch_data 返回 obj_get 和 get_object_list 等数据?以下是有问题的一段代码:

#Object class
Class Entry(object)
    name = ''


#Resource class
class EntryResource(Resource):
    name = fields.CharField(attribute = 'name')

    class Meta:
        resource_name = 'entry'
        object_class = Entry
        include_resource_uri = False 
        authentication = Authentication()
        authorization = Authorization()
        serializer = Serializer()

    def override_urls(self):
        return [url(r"^(?P<resource_name>%s)/(?P<p1>[\d]{4})/(?P<p2>[\d]{4})%s$" % (self._meta.resource_name, trailing_slash()), self.wrap_view('dispatch_data'),name='api_dispatch_data'),]

    def dispatch_data(self, request, **kwargs):
         p1 = kwargs['p1'] #params can be retrieved here
         p1 = kwargs['p2']
         info = Entry()
         info.name = p1 #just example
         response = {1:info}
         return info.values() 
         #Above results in ERROR, it will say Entry object has no attribute 'has_header' 
         #changing to self.create_response(request, info) will not serialize the fields



#urls.py
api = Api(api_name='v1')
api.register(EntryResource())

urlpatterns = patterns('',
    url(r'^api/', include(api.urls)),
)
4

1 回答 1

0

我认为 Tastypie's Using Tastypie With Non-ORM Data Sources拥有您需要的所有信息。

基本上你应该实现负责返回对象的方法(和/或创建、删除等......如果你需要它们)。除非您需要自定义它的功能,否则您无需触摸“dispatch()”。

这取决于您的需求,但是如果您希望资源的行为就像它具有 obj_get 和 obj_get_list 一样,您需要实现这两者。我提到的例子非常好,应该让你继续......

于 2012-03-08T14:38:40.490 回答