Подтвердить что ты не робот

Неверный способ определить, является ли iframe кросс-доменом

Я пытаюсь определить, является ли какой-либо iframe междоменным или нет. В соответствии с принятым ответом в этом вопросе: Обнаруживать, когда iframe является кросс-доменом, а затем вырывается из него, он говорит, что код, доступ к contentDocument iframe в блоке try / catch. Я пробовал это для междоменного iframe в Chrome:

try { 
  document.getElementsByTagName('iframe')[0].contentDocument;
} catch(err){
  console.log("called");
}

и он по-прежнему выбрасывает междоменную ошибку и не улавливает ошибку.

Я также пытался проверить, находится ли протокол + хост + порт родительского URL-адреса в src iframe:

function thirdPartyIframe(iframe){
  var url = document.location.protocol + "//" + document.location.hostname + (document.location.port === "" ? "" : ":" + document.location.port);
  var regexp = new RegExp(url.replace(/\//g, "\\/").replace(/\./g, "\\."));
  if (iframe.src === '' || regexp.test(iframe.src)){
    return false;
  } else {
    return true;
  }
}

но это, похоже, не работает для первого iframe на домашней странице Facebook с src равным (длинным):

"http://www.facebook.com/ai.php?aed=AQLlH2cfdnsnLrDUVyqrQPlWpayw9N09Z_iNuhulevbeEfVa4mcVRcT8cjAZOjQb8y1QXab5Ae3aSEJx49U_Qv35rtSp1VC9cY0_CrpOjMDk40hS_Xm57A996YtRVCcWSuRZ_jZERQ_iA_E4621NAbKHT9dsB7uElkRtTvl5K-zPI0jeH-BEnlZIOXbeEdbRC6qCwoToaltolpe-Ot2KWgkfb_vBZYpzUc3jQoEHzLG6tauO9l_hkXpYpHxnt-KYFKIFZ1PgmrHgb0UcGjeKHl7yBR1AbW2n5XgdgaAhFvBjs5GZlKy566nvl8eLRA60orwkwtWYeN8-gKoAmOLm7-6minsWn8lk1h2Qn3p07HCTSnYHfv1aJ6mF5jmuzP0YYe7Ym9ZbmK-tvax4uPAQJ2OdULilKbEh8M-2V9pVY3AC228OPlrRullZuuOg8DI2A8WeMF-fbbOdOFFVCe5Gj1CaZu3LYXiqdG7mUgY6AEpk9ZzGT4fC2K8DInQo1AypCvzG64C_bEWfODeXe0aGbkWwsUUmO7E5HFg0tvZkK5IAR_xxxQ2rlf5jbcEDo_2gdIDdHe1HT75-SJLUsSA0M8EU01oNNPuWwEC2BW6inepc9QPuqeg42tcEbKLU-rIUnXDBLvgutft8azWPPQ6_LafGjCAmC9uTalagoWLLDMpQOThvPg7YeVd7qg_c9Mzn2GAfuswcxDSxyRIZo9MaOhA6mhfXeE1tmjyBBsMxnx08tO21Jsfgch59fmMxpeJzdsNMPK3FAojfglvCQ2Zrt_6ataexUB4xlM7_PhKrfBPtxb5fe2TE9-nlWruNEpoCrzI05yv4Go3CYEWHob06K_9iICfNVTFkSYGTiJnMXCy_fdgfyzUIn5QJIPRo4-Wnyg444zKAO_nyFW59LqbIanHVfFY6ybiA6KeC3meREWzTPSsrU5d_NbYHlJWb8uPNDR04jaH5e2qiYj3Y8qgLQA5m"

Моя функция классифицирует его как сторонний iframe, но Chrome по-прежнему бросает междоменную ошибку, когда я обращаюсь к ее contentDocument.

Я ищу надежный, кросс-браузерный способ сделать это.

4b9b3361

Ответ 1

Вам нужно сделать немного больше, чем в вашем try/catch, чтобы обрабатывать разные браузеры и обрабатывать различные способы, с которыми браузеры сталкиваются с перекрестным доступом к домену:

function canAccessIFrame(iframe) {
    var html = null;
    try { 
      // deal with older browsers
      var doc = iframe.contentDocument || iframe.contentWindow.document;
      html = doc.body.innerHTML;
    } catch(err){
      // do nothing
    }

    return(html !== null);
}

В вашем примере это будет:

var accessAllowed = canAccessIFrame(document.getElementsByTagName('iframe')[0]);

Рабочая демонстрация: http://jsfiddle.net/jfriend00/XsPL6/

Протестировано в Chrome 21, Safari 5.1, Firefox 14, IE7, IE8, IE9.