Firefox 插件 - 监控网络

use*_*314 6 firefox-addon

如果我添加一个 nsIHttpChannel 观察者,有什么办法可以知道是什么发起了 HTTP 请求(脚本、iframe、图像等)

在 chrome 中从后台页面监控网络时,您有请求类型告诉您它是否来自 iframe、脚本等...

Noi*_*art 7

不要接受这个作为解决方案。我希望其他一些人可以来帮助构建这个解决方案。

我知道这肯定是正确的:

我认为这是正确的,我的意思是它适用于我的测试用例,但我不确定它是否是推荐的方式:

我不知道该怎么做,所以我需要社区的帮助:


解决方案进行中:

var myobserve = function(aSubject, aTopic, aData) {
    var httpChannel = aSubject.QueryInterface(Ci.nsIHttpChannel);


    //start - test if xhr
    var isXHR;
    try {
        var callbacks = httpChannel.notificationCallbacks;
        var xhr = callbacks ? callbacks.getInterface(Ci.nsIXMLHttpRequest) : null;
        isXHR = !!xhr;
    } catch (e) {
        isXHR = false;
    }
    //end - test if xhr

    //start - test if frame OR full page load
    var isFrameLoad;
    var isFullPageLoad;
    if (httpChannel.loadFlags & Ci.nsIHttpChannel.LOAD_INITIAL_DOCUMENT_URI) {
        isFullPageLoad = true;
        isFrameLoad = false;
    } else if (httpChannel.loadFlags & Ci.nsIHttpChannel.LOAD_DOCUMENT_URI) {
        isFrameLoad = true;
        isFullPageLoad = false;
    }
    //end - test if frame OR full page load

    //start - test if image
    var isImg;
    var isCss;
    var isJs;
    var isAudio;
    //can keep going here
    var mimeType = httpChannel.contentType;
    if (/^image/i.test(mimeType)) {
        isImg = true;
    }
    if (/^audio/i.test(mimeType)) {
        isAudio = true;
    }
    if (/\/css$/i.test(mimeType)) {
        isCss = true;
    }
    if (/\/js$/i.test(mimeType)) {
        isJs = true;
    }
    //end - test if image

    //start - OPTIONAL use loadContext to get a bunch of good stuff
    //must paste the function from here: https://gist.github.com/Noitidart/644494bdc26f996739ef somewhere in your code
    var goodies = loadContextAndGoodies(aSubject, true);
    /*
    //goodies is an object that holds the following information:
    var goodies = {
        loadContext: loadContext,
        DOMWindow: DOMWindow,
        gBrowser: gBrowser,
        contentWindow: contentWindow,
        browser: browser,
        tab: tab
    };
    */
    // test if resource (such as image, or whatever) is being loaded is going into a frame [can also be used as altnerative way to test if frame load or full page]
    var itemDestinationIsFrame;
    var itemDestinationIsTopWin;
    if (goodies.contentWindow) {
        if (goodies.contentWindow.frameElement) {
            itemDestinationIsFrame = true;
            itemDestinationIsTopWin = false;
        } else {
            itemDestinationIsFrame = false;
            itemDestinationIsTopWin = true;
        }
    }
    //end - OPTIONAL use loadContext to get a bunch of good stuff
}
Run Code Online (Sandbox Code Playgroud)

当然要开始观察:

Services.obs.addObserver(myobserve, 'http-on-modify-request', false);
Run Code Online (Sandbox Code Playgroud)

并停止:

Services.obs.removeObserver(myobserve, 'http-on-modify-request', false);
Run Code Online (Sandbox Code Playgroud)

开始观察

要开始观察所有请求,请执行此操作(例如在您的插件启动时)

for (var o in observers) {
    observers[o].reg();
}
Run Code Online (Sandbox Code Playgroud)

停止观察

停止观察很重要(确保至少在插件关闭时运行它,你不想因为内存原因让观察者注册)

for (var o in observers) {
    observers[o].unreg();
}
Run Code Online (Sandbox Code Playgroud)

  • 惊人的合成再次非常感谢!...您在这里链接的有趣主题 (2认同)