在以下示例中覆盖了URL,以便我可以传递类似的内容 http://localhost:8000/api/v1/entry/1234/1233/?format=json,这样做会将参数传递给WRAP VIEW,当我执行self.create_response(请求,数据)时,浏览器只显示类似
的内容api.Entry对象位于0x2e27a50
在浏览器中,字段不会被序列化: 注意:我现阶段不需要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)),
)
答案 0 :(得分:0)
我认为Tastypie的Using Tastypie With Non-ORM Data Sources拥有您需要的所有信息。
基本上你应该实现负责返回对象的方法(和/或创建,删除等......如果你需要它们)。除非您需要自定义它的功能,否则您无需触摸“dispatch()”。
这取决于您的需求,但如果您希望资源如果它具有obj_get和obj_get_list,则需要实现这两者。我提到的例子非常好,应该让你去...