如何解决使用Blogger API删除帖子
我正在使用Blogger协议API,但无法删除帖子。我正在使用WebOS设备,因此无法直接发送DELETE
;相反,我使用Google的解决方法来使用ѭ1around:
deletePostList: function(event)
{
var deletePostID = event.item.id.split(\'.\').pop().split(\'-\').pop();
var deleteRequest = new Ajax.Request(\"http://www.blogger.com/Feeds/\" + activeBlogID + \"/posts/default/\" + deletePostID,{
method: \'post\',requestHeaders:
{
Authorization: \'GoogleLogin auth=\' + authCode,\"X-HTTP-Method-Override\": \"DELETE\",\"If-Match\": \"*\"
},onSuccess: this.deletePostRequestSuccess.bind(this),onFailure: this.deletePostRequestFailure.bind(this)
});
},
这似乎可行,即在此过程之后调用``3'',并且所有标题和响应文本看起来都像我在删除帖子时应该使用的,但现实情况是帖子仍保留在提要中。我尝试添加\“ If-Match \”标头,以确保它不是阻止我的GData有条件删除(即使此时我没有更改帖子中的任何内容),但这也没有似乎没有帮助。
关于如何进行这项工作的任何想法?我想坚持使用Protocol,因为它是webOS上的本机,而jQuery等不是。
解决方法
据我所知,HTTP方法的问题不是webOS,而是源于Prototype。
我建议创建一个子类:
<script type=\"text/javascript\">
var MyAjaxRequest = Class.create(Ajax.Request,{
request: function(url) {
this.url = url;
this.method = this.options.method;
var params = Object.isString(this.options.parameters) ?
this.options.parameters :
Object.toQueryString(this.options.parameters);
/* comment out this stuff that prevents you from using the DELETE method
if (![\'get\',\'post\'].include(this.method)) {
// simulate other verbs over post
params += (params ? \'&\' : \'\') + \"_method=\" + this.method;
this.method = \'post\';
}
* /
if (params && this.method === \'get\') {
// when GET,append parameters to URL
this.url += (this.url.include(\'?\') ? \'&\' : \'?\') + params;
}
this.parameters = params.toQueryParams();
try {
var response = new Ajax.Response(this);
if (this.options.onCreate) this.options.onCreate(response);
Ajax.Responders.dispatch(\'onCreate\',this,response);
this.transport.open(this.method.toUpperCase(),this.url,this.options.asynchronous);
if (this.options.asynchronous) this.respondToReadyState.bind(this).defer(1);
this.transport.onreadystatechange = this.onStateChange.bind(this);
this.setRequestHeaders();
this.body = this.method == \'post\' ? (this.options.postBody || params) : null;
this.transport.send(this.body);
/* Force Firefox to handle ready state 4 for synchronous requests */
if (!this.options.asynchronous && this.transport.overrideMimeType)
this.onStateChange();
}
catch (e) {
this.dispatchException(e);
}
});
script>
这样你就可以用method: \'DELETE\'
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。