某些网站不允许通过iframe嵌入。它们产生以下错误:
Refused to display 'https://news.ycombinator.com/news' in a frame because it
set 'X-Frame-Options' to 'DENY'.
我们的应用程序允许用户提交 URL。我们想在服务器端检查网站是否可以嵌入到 iframe 中并添加相应的标志。在客户端上,我们检查标志,然后进行iframe嵌入或仅提供指向网页的直接链接。
如何检查网站是否支持 iframe?
试试这段代码:
$url = "http://www.google.com/";
$url_headers = get_headers($url);
foreach ($url_headers as $key => $value)
{
$x_frame_options_deny = strpos(strtolower($url_headers[$key]), strtolower('X-Frame-Options: DENY'));
$x_frame_options_sameorigin = strpos(strtolower($url_headers[$key]), strtolower('X-Frame-Options: SAMEORIGIN'));
$x_frame_options_allow_from = strpos(strtolower($url_headers[$key]), strtolower('X-Frame-Options: ALLOW-FROM'));
if ($x_frame_options_deny !== false || $x_frame_options_sameorigin !== false || $x_frame_options_allow_from !== false)
{
echo 'url prevent iframe!';
}
}
X-Frame-Options
是服务器发送的响应标头,因此请让您的服务器对要测试的URL执行HTTP GET,查看X-Frame-Options
标头是否存在,如果存在...从规范来看,您根本不可能被允许嵌入它。
我写了这个函数:
function allowEmbed($url) {
$header = @get_headers($url, 1);
// URL okay?
if (!$header || stripos($header[0], '200 ok') === false) return false;
// Check X-Frame-Option
elseif (isset($header['X-Frame-Options']) && (stripos($header['X-Frame-Options'], 'SAMEORIGIN') !== false || stripos($header['X-Frame-Options'], 'deny') !== false)) {
return false;
}
// Everything passed? Return true!
return true;
}