Firefox插件中的Ajax

时间:2010-03-18 16:39:33

标签: firefox-addon

有没有办法从Firefox插件向服务器发送Ajax请求?如果有,怎么样?如果不是,我们如何在Firefox插件中进行客户端服务器通信?

我想从服务器获取一些json数据,并根据客户端输入操作dom对象。

我是插件编程的初学者

此致 吉希纳

3 个答案:

答案 0 :(得分:3)

您可以使用xmlHTTPRequest从firefox扩展程序发送ajax请求,就像在任何其他Web应用程序中一样。

答案 1 :(得分:3)

从内容脚本中,您应该添加访问跨域内容的权限,您想要的URL:

"permissions": {
    "cross-domain-content": ["http://example.org/", "http://example.com/"]
}

More info in the documentation

答案 2 :(得分:2)

这是一个执行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);
});