簡體   English   中英

在http-on-examine-response之前返回響應

[英]Return response before http-on-examine-response

我正在開發一個Firefox插件,它需要攔截HTTP請求進程並返回某些URL的虛假響應。 這是我正在使用的代碼:

function TracingListener() {
    this.originalListener = null;
}

TracingListener.prototype = {
    onDataAvailable: function(request, context, inputStream, offset, count) {
        LOG("onDataAvailable");
        this.originalListener.onDataAvailable(request, context, inputStream, offset, count);
    },

    onStartRequest: function(request, context) {
        LOG("onStartRequest");
        this.originalListener.onStartRequest(request, context);
    },


    onStopRequest: function(request, context, statusCode) {
        LOG("onStopRequest");
        this.originalListener.onStopRequest(request, context, statusCode);
        var stream = Cc["@mozilla.org/io/string-input-stream;1"].createInstance(Ci.nsIStringInputStream);
        stream.setData("Test", -1);
        this.originalListener.onStopRequest(request, context, Components.results.NS_OK);

    },

    QueryInterface: function (aIID) {
        if (aIID.equals(Ci.nsIStreamListener) ||
        aIID.equals(Ci.nsISupports)) {
            return this;
        }
        throw Components.results.NS_NOINTERFACE;
    }
};

var observer = {
    observe: function(subject, topic, data) {
        LOG(topic);
        var httpChannel = subject.QueryInterface(Ci.nsIHttpChannel);
        var url = httpChannel.URI.spec;
        LOG("Test:" + url);
        if (!pattern.test(url)) return;

        if (topic == 'http-on-modify-request') {
            var newListener = new TracingListener();
            newListener.originalListener = httpChannel.setNewListener(newListener);

            } else if (topic == "http-on-examine-response" || topic == "http-on-examine-cached-response" || topic == "http-on-examine-merged-response") {
            var newListener = new TracingListener();
            newListener.originalListener = httpChannel.setNewListener(newListener);
        }
    }
};


var observerService = Cc["@mozilla.org/observer-service;1"].getService(Ci.nsIObserverService);
observerService.addObserver(observer, "http-on-modify-request", false);
observerService.addObserver(observer, "http-on-opening-request", false);

當有URL響應時它可以正常工作:我可以將響應更改為“Test”。

但是,對於某些無法訪問或非常慢的URL,永遠不會調用onStopRequest

我需要在發送任何實際請求之前返回請求,即“http-on-open-request”或“http-on-modify-request”。 但在那時,Firefox拒絕接受任何回復,因為他認為(這是真的)響應不應該可用。

我怎樣才能做到這一點?

http-on-modify-request ,您應該能夠調用redirectTo或修改nsIChannel.URI以將請求發送到數據URI,如data:text/plain,Test

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM