在Chrome扩展程序中使用PAC文件重定向HTTPS请求似乎失败了

时间:2015-02-09 15:46:49

标签: javascript google-chrome google-chrome-extension https pac

我为自己和同事设置了 Chrome扩展程序(版本40)

其中一项功能是自动将浏览器中收到的请求重定向到我们的登台服务器IP地址。这使我们可以避免编辑主机文件,以便像目前那样在暂存和生产之间切换。每分钟都很重要..

无论如何,当我为HTTP请求使用代理配置时,我设置的以下脚本运行正常。但是当尝试在使用https请求URL的站点上运行它时,它会失败并出现以下错误。

  

净:: ERR_TUNNEL_CONNECTION_FAILED

这是我到目前为止设置的代码的主要要点。

PAC Filehttps://awesomeurl.com/proxy.pac

function FindProxyForURL(url, host) {
  var domains = ["url1", "url2", "url3", "url4"], // fake company urls
      base = ".awesomecompany.com",
      ii;

  // our local URLs from the domains below example.com don"t need a proxy:

  for(ii=0; ii<domains.length; ii++) {
    if(shExpMatch(host, domains[ii] + base)) {
      return "PROXY 11.111.111.111"; // Fake IP Address
    }
  }
  return "DIRECT";
}

这是生成Chrome设置的脚本。持久性在其他地方完成。

/**
 * Checks which value has been selected and generates the proxy config that will
 * be used for the the chrome settings and persisted.
 *
 * @param {string} mode The mode requested by the user
 * @return {ProxyConfig} the proxy configuration reprensented by the user's selections
 * @public
 *
 */
function generateProxyConfig(mode) {
  switch(mode) {
    case proxyValues.NORMAL:
      return { mode: 'system' }

    case 'production':
      return {
        mode: 'pac_script',
        pacScript: {
          url: 'https://awesomeurl.com/proxy.pac',
          mandatory: true
        }
      }
  }
}

function applyChanges ( mode, cb ) {
  config = generateProxyConfig( mode );

  chrome.proxy.settings.set({
    value: config,
    scope: 'regular'
  }, cb );
}

applyChanges('production', function() {console.log('Why doesn't this work for https') })

我发现的唯一资源甚至是远程相关的was this one。这似乎意味着,对于iOS,由于安全隐患,PAC文件无法用于重定向HTTPS流量。

我想我想知道这与Chrome是否相同。请提供任何已知的潜在解决方法。

1 个答案:

答案 0 :(得分:1)

好的 - 这是一个潜在的问题解决方案,而不是一个非常优雅的问题。

我能够使用webRequest建议的Xan API。

首先,我将以下权限添加到manifest.json文件中。

"permissions": [
    "tabs",
    "activeTab",
    "http://*/*",
    "https://*/*",
    "proxy", 
    "webRequest", // new
    "webRequestBlocking" // new
  ],

然后在加载脚本后立即运行的新文件中。我能够使用以下内容。

// Let's play around with redirecting all https requests to http
'use strict';

console.info('awesome is here')
var domains = ["url1", "url2", "url3", "url4"], 
    base = ".awesomecompany.com";

chrome.webRequest.onBeforeRequest.addListener(
  function(details) {
    console.log(details);
    return {redirectUrl: details.url.replace('https', 'http')};
  }, {urls: domains.map(function(domain) {var url = 'https://' + domain + base + '/*'; return url;})},["blocking"]
);

所以基本上我将所有的URL重定向到http并且它正在工作。

这种 hack 让我内心感觉非常糟糕 - 但我已经花了太多时间寻找解决方案。