1

サーバーからの Web ページをコントロールおよび情報パネルとして表示する FireFox アドオンを作成しています。これらのパネルは通常の URL で記述され、動作しますが、カスタム プロトコル (つまり、myplugin:settings のようなもの) を介してアクセスしようとすると、XSS を行っているかのように、すべての XMLHttpRequest が空白を返します。私はデータが通過していることを知っています - 要求は有効で、サーバーによって受け入れられ、tcpdump はそれらが私のマシンに到達していると言っています。明らかに、これはカスタム プロトコルの実装と関係があるため、関連する部分を次に示します。

    newURI: function(spec, charset, baseURI)
    {
        var uri = Components.classes[@"mozilla.org/network/simple-uri;1"].createInstance(nsIURI);

        if (baseURI) {
            spec = "myplugin:" + spec;
        }

        uri.spec = spec;

        return(uri);
    },

    newChannel: function(aURI)
    {
        var incomingURI = aURI.spec;
        var purpose = incomingURI.substring(incomingURI.indexOf(":") + 1, incomingURI.length);
        var my_spec;
        var my_uri;
        var proto;

 var api_scheme = "http";
 var api_host = "myapi.myserver.com";
 var api_token = "temp";

        purpose = encodeURI(purpose);

        if(purpose.match(/^\//)) // If it begins with a "/" (relative URL)
            if(purpose.match(/\?/)) // It already contains a query string
                my_spec = api_scheme + "://" + api_host + purpose + "&api_token=" + api_token;
            else
                my_spec = api_scheme + "://" + api_host + purpose + "?api_token=" + api_token;
        else
            my_spec = api_scheme + "://" + api_host + "/frontend/" + purpose + "?api_token=" + api_token;

        my_uri = Components.classes[@mozilla.org/network/simple-uri;1].createInstance(nsIURI);
        my_uri.spec = my_spec;
        proto = Components.classes["@mozilla.org/network/protocol;1?name="+api_scheme].getService(nsIProtocolHandler);

        return (proto.newChannel(my_uri));
    }
};
4

1 に答える 1

1

仕様の目には、あなたはxssをやっています。

実装はプラットフォームによって若干異なりますが、一般的な経験則は、同じプロトコル、同じドメイン、同じポートです。

于 2010-04-08T19:06:45.620 に答える