是否可以通过Firefox插件将Ajax请求发送到服务器?如果是,怎么办?如果没有,我们如何在Firefox插件中进行客户端服务器通信?
我想从服务器获取一些JSON数据,并根据客户端输入来操作DOM对象。
我是插件编程的初学者。
您可以像其他任何Web应用程序一样,使用xmlHTTPRequest从firefox扩展名发送ajax请求。
从目录脚本中,您应该添加访问跨域内容的权限,您要访问的URL:
"permissions": {
"cross-domain-content": ["http://example.org/", "http://example.com/"]
}
这是一个XHR请求的简单代码段,没有cookie(由于标志Ci.nsIRequest.LOAD_ANONYMOUS
可以删除以与cookie一起发送)(MDN :: Info on flags]。复制此第一个代码块,然后查看下面的用法示例。
var {Cu: utils, Cc: classes, Ci: instances} = Components;
Cu.import('resource://gre/modules/Services.jsm');
function xhrGetPost(url, post_data, cb) {
let xhr = Cc["@mozilla.org/xmlextras/xmlhttprequest;1"].createInstance(Ci.nsIXMLHttpRequest);
let handler = ev => {
evf(m => xhr.removeEventListener(m, handler, !1));
switch (ev.type) {
case 'load':
if (xhr.status == 200) {
cb(xhr.response);
break;
}
default:
Services.prompt.alert(null, 'XHR Error', 'Error Fetching Package: ' + xhr.statusText + ' [' + ev.type + ':' + xhr.status + ']');
break;
}
};
let evf = f => ['load', 'error', 'abort'].forEach(f);
evf(m => xhr.addEventListener(m, handler, false));
xhr.mozBackgroundRequest = true;
if (post_data == undefined) {
post_data = null;
}
if (post_data) {
xhr.open('POST', url, true);
} else {
xhr.open('GET', url, true);
}
xhr.channel.loadFlags |= Ci.nsIRequest.LOAD_ANONYMOUS | Ci.nsIRequest.LOAD_BYPASS_CACHE | Ci.nsIRequest.INHIBIT_PERSISTENT_CACHING;
//xhr.responseType = "arraybuffer"; //dont set it, so it returns string, you dont want arraybuffer. you only want this if your url is to a zip file or some file you want to download and make a nsIArrayBufferInputStream out of it or something
xhr.send(post_data);
}
POST
的用法示例:var href = 'http://www.bing.com/'
xhrGetPost(href, 'post_data1=blah&post_data2=blah_blah', data => {
Services.prompt.alert(null, 'XHR Success', data);
});
GET
的用法示例:var href = 'http://www.bing.com/'
xhrGetPost(href, null, data => {
Services.prompt.alert(null, 'XHR Success', data);
});