1

拡張機能をシークレット モードでのみ機能させようとしています。manifest.json に追加"incognito": "split"し、background.js に if ステートメントを追加してchrome.extension.inIncognitoContext.

編集:

さて、私がやろうとしているのは、シークレット モードでのみユーザー エージェント ヘッダーを変更することです。私はこれに基づいてこれを行っています: http://elaineou.com/2016/02/19/how-to-use-chrome-extensions-to-bypass-paywalls/

上記のリンクでは機能しますが、シークレット モードではすべての Web サイトで機能するようには見えません。これもリリースされず、シークレットボタンで許可されています。

マニフェスト.json

{
  "name": "Incognito Chrome Extension",
  "version": "0.1",
  "description": "This is an incognito chrome extension.",
  "incognito": "split",
  "permissions": ["webRequest", "webRequestBlocking",
                   "http://localhost:3000/",
                   "http://*/*",
                   "https://*/*"
                  ],
  "background": {
    "scripts": ["background.js"]
  },
  "manifest_version": 2
}

Background.js

var ALLOW_COOKIES = [""];
if(chrome.extension.inIncognitoContext){
    function changeRefer(details) {
    foundReferer = false;
    foundUA = false;

    var reqHeaders = details.requestHeaders.filter(function(header) {
      // block cookies by default
      if (header.name !== "Cookie") {
        return header;
      } 

      allowHeader = ALLOW_COOKIES.map(function(url) {
        if (details.url.includes(url)) {
          return true;
        }
        return false;
      });
      if (allowHeader.reduce(function(a, b) { return a || b}, false)) { return header; }

    }).map(function(header) {

      if (header.name === "Referer") {
        header.value = "https://www.google.com/";
        foundReferer = true;
      }
      if (header.name === "User-Agent") {
        header.value = "Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko";
        foundUA = true;
      }
      return header;
    });

    // append referer
    if (!foundReferer) {
      reqHeaders.push({
        "name": "Referer",
        "value": "https://www.google.com/"
      });
    }
    if (!foundUA) {
      reqHeaders.push({
        "name": "User-Agent",
        "value": "Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko"
      });
    }
    console.log(reqHeaders);
    return {requestHeaders: reqHeaders};
  }

  function blockCookies(details) {
    for (var i = 0; i < details.responseHeaders.length; ++i) {
      if (details.responseHeaders[i].name === "Set-Cookie") {
        details.responseHeaders.splice(i, 1);
      }
    }
    return {responseHeaders: details.responseHeaders};
  }

  chrome.webRequest.onBeforeSendHeaders.addListener(changeRefer, {
    urls: ["<all_urls>"],
    types: ["main_frame"],
  }, ["requestHeaders", "blocking"]);

  chrome.webRequest.onHeadersReceived.addListener(blockCookies, {
    urls: ["<all_urls>"],
    types: ["main_frame"],
  }, ["responseHeaders", "blocking"]);
}
4

1 に答える 1

1

あなたの懸念は余分な冗長なバックグラウンド ページ プロセスだと思いますか?

マニフェスト ファイルを追加"incognito": "split"し、非シークレット モードで拡張機能のバックグラウンド ページを閉じます。

// background page or event page:
if (!chrome.extension.inIncognitoContext) {
    window.close();
}

コンテンツ スクリプトは、引き続き非シークレット ページで実行されます。これに対抗するには、拡張機能がシークレット モードで実行されているかどうかを確認した後、コードを終了します (上記の確認と同様)。

注: 拡張機能が公開され、シークレット モードでのみ役立つ場合は、シークレット モードが有効になっているかどうかを確認し、無効になっている場合は手順を提供することを検討してください。たとえば、Chrome 拡張機能をシークレット モードで有効にするにはどうすればよいですか? を参照してください。

于 2016-07-04T08:18:57.703 に答える