更新 2:
不幸的是,YouTube 放弃了对这种方法的支持。希望将来会有一个新的解决方案,而不使用他们的 API(因为它有报价限制)。
试试这个链接:https://www.youtube.com/live_stats?v={videoid}
在 YouTube 上查找直播活动并替换链接中的视频 ID。这应该检索该特定视频的并发观看次数。
如果是,请刷新页面并将数量与 YouTube 页面上的同时观看人数进行比较。
更新 1:
以下是如何将其添加到您的网站的示例。可以设置一个php文件和一个html文件。
viewers.php:
<?php
$viewers = file_get_contents('https://www.youtube.com/live_stats?v=y60wDzZt8yg');
echo $viewers;
?>
viewers.html:
<!DOCTYPE html>
<html>
<body>
<div id="status" style="color: #666; line-height: 24px; font-size: 19px; font-weight: normal; font: 19px Roboto,arial,sans-serif;"></div>
<script src="http://code.jquery.com/jquery-1.7.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
function update() {
$.ajax({
url: 'viewers.php',
dataType: 'text',
success: function(data) {
if (parseInt(data) == 0) {
$("#status").css({ display: "none" });
} else {
$("#status").text(parseInt(data) + ' watching now' );
}
}
})
}
update();
var statusIntervalId = window.setInterval(update, 5000);
</script>
</body>
</html>
如您所见,我使用 PHP 文件通过 live_stats 链接从 YouTube 检索数据。然后我使用带有 jquery 的 HTML 每 5 秒动态更新一次数据。
<div id="status"... 是显示数据的地方,并带有一点 css 样式。
<script src="... 是加载 jQuery 库的地方。
<script type="... 是 jQuery 从PHP 文件并显示在第一个 div / 如果有 0 个查看者,则隐藏它。
我在想您可以将它嵌入到不会刷新整个页面的 iframe 中。您也可以直接将 html 代码嵌入到网页中,而无需 iframe。如果您将直接嵌入,如果 PHP 文件不在同一个相对文件夹中,则必须设置其直接路径。如果有任何错误,只需使用开发人员工具控制台进行故障排除。
请注意,在第一个 jQuery 间隔刷新数据之前,不会显示查看者的数量。在这种情况下,5 秒。 我更新了这个,所以第一次更新不需要 5 秒。现在应该可以立即使用了。
这是它为我工作的图像:
希望这会有所帮助...