更新:我能够以非常倒退的方式对数据进行PUT /更新 - 对我而言似乎更像是一个漏洞或安全漏洞?
ProjectViewModel.prototype.edit = function (projectId, project) {
var _project = JSON.parse(project);
_project.id = projectId;
_project.name = "test 123!";
project = JSON.stringify(_project);
$.ajax({
url: "http://" + window.location.href.split("/")[2] + "/api/v1/project/",
type: "POST",
data: project,
contentType: "application/json",
processData: false,
success: function (data) {
$("#div_response").text("updated!");
},
error: function (data) {
$("#div_response").text(data.responseText);
}
});
};
上面的代码允许我将一个新对象发布到Tastypie,如果我包含对象id值,我将更新现有对象而不是创建一个新对象。
原文问:
我能够进行GET和POST但无法使用Tastypie进行PUT或PATCH。以下是我的API:
from tastypie.resources import ModelResource
from tastypie.authentication import Authentication
from tastypie.authorization import DjangoAuthorization, Authorization
from tastypie import fields
from ProjectTrackerServer.projects.models import Project
from ProjectTrackerServer.milestones.models import Milestone
class ProjectResource(ModelResource):
# namespace-to-milestones, related_name-from-milestones-model, show-full
milestones = fields.ToManyField('ProjectTrackerServer.projects.api.MilestoneResource', 'projects', full=True)
class Meta:
queryset = Project.objects.all()
resource_name = 'project'
allowed_methods = ['get', 'post', 'put', 'delete', 'patch']
authentication = Authentication()
authorization = Authorization()
class MilestoneResource(ModelResource):
project = fields.ToOneField('ProjectTrackerServer.projects.api.ProjectResource', 'project')
class Meta:
queryset = Milestone.objects.all()
resource_name = 'milestone'
allowed_methods = ['get', 'post', 'put', 'delete', 'patch']
authentication = Authentication()
authorization = Authorization()
快速回顾一下我的Javascript Ajax代码,其中'projectId'是方法的参数:
//this is just a test for using PUT/PATCH by fetching a project,
//updating it, and saving it back to the server.
$.ajax({
url: "http://" + window.location.href.split("/")[2] + "/api/v1/project/" + projectId + "/",
type: "GET",
data: "",
contentType: "application/json",
processData: false,
success: function (data) {
var project = data;
project.name = "Project Y!";
project.slug = "project-y";
var jsondata = JSON.stringify(project);
$.ajax({
url: "http://" + window.location.href.split("/")[2] + "/api/v1/project/" + projectId + "/",
type: "PATCH",
data: jsondata,
contentType: "application/json",
processData: false,
crossDomain: true,
headers: {
"X-HTTP-Method-Override": "PATCH"
},
success: function (data) {
$("#div_response").text(data.responseText);
},
error: function(data) {
$("#div_response").text(data.responseText);
}
});
},
error: function (data) {
$("#div_response").text(data.responseText);
}
});
奇怪的是我没有收到错误。如果我尝试输出“数据”,使用JSON.stringify(),我只会得到双引号(“”)。
如果有帮助,我也会包括我的模特。
from django.db import models
from django.template.defaultfilters import slugify
class Project(models.Model):
name = models.CharField(max_length=200)
start_date = models.DateField()
end_date = models.DateField()
pm_id = models.IntegerField()
status = models.IntegerField()
slug = models.SlugField()
def __unicode__(self):
return self.name
def save(self, *args, **kwargs):
if not self.slug:
self.slug = slugify(self.name)[:50]
return super(Project, self).save(*args, **kwargs)
更新:我能够很好地获取和发布,所以我不确定为什么curl会响应它无法解析主机。这是我使用cURL得到的结果:
C:\curl>curl --dump-header - -H "Content-Type: application/json" -X PUT --data
{{"end_date": "2014-10-10", "id": "16", "milestones": [], "name": "Project XY!
"resource_uri": "/api/v1/project/16/", "slug": "project-x", "start_date": "20
-12-30", "status": 1}}' http://localhost:1231/api/v1/project/16
curl: (6) Could not resolve host: (nil); No data record of requested type
curl: (6) Could not resolve host: (nil); Host not found
curl: (6) Could not resolve host: (nil); No data record of requested type
curl: (6) Could not resolve host: (nil); Host not found
curl: (3) [globbing] illegal character in range specification at pos 2
curl: (6) Could not resolve host: (nil); Host not found
curl: (6) Could not resolve host: (nil); No data record of requested type
curl: (6) Could not resolve host: (nil); Host not found
curl: (3) <url> malformed
curl: (6) Could not resolve host: (nil); Host not found
curl: (6) Could not resolve host: (nil); No data record of requested type
curl: (6) Could not resolve host: (nil); Host not found
curl: (6) Could not resolve host: (nil); No data record of requested type
curl: (6) Could not resolve host: (nil); Host not found
curl: (3) [globbing] unmatched close brace/bracket at pos 2
HTTP/1.0 301 MOVED PERMANENTLY
Date: Wed, 20 Feb 2013 19:58:56 GMT
Server: WSGIServer/0.1 Python/2.7.3
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: POST,GET,OPTIONS,PUT,DELETE
Content-Type: text/html; charset=utf-8
Location: http://localhost:1231/api/v1/project/16/
Access-Control-Allow-Headers: Origin,Content-Type,Accept