处理Youtube嵌入限制

时间:2017-02-16 09:12:59

标签: c# wpf youtube webbrowser-control embed

我实际上正在开发JARVIS助手 它将有很多模块但我从一个简单的开始。

Youtube One。所以全屏或隐藏的主窗口都有一个WebBrowser

    private static string GetYouTubeVideoPlayerHTML(string videoCode)
    {
        var sb = new StringBuilder();

        const string YOUTUBE_URL = @"http://www.youtube.com/embed/";

        sb.Append("<html>");
        sb.Append("    <head>");
        sb.Append("        <meta name=\"viewport\" content=\"width=device-width; height=device-height;\">");
        sb.Append("    </head>");
        sb.Append("    <body marginheight=\"0\" marginwidth=\"0\" leftmargin=\"0\" topmargin=\"0\" style=\"overflow-y: hidden\">");
        sb.Append($"        <iframe width=\"100%\" height=\"100%\" src =\"{YOUTUBE_URL}{videoCode}?autoplay=1&showinfo=0&controls=0\" frameborder = \"0\" allowfullscreen>");
        sb.Append("    </body>");
        sb.Append("</html>");

        return sb.ToString();
    }

这将返回我使用的字符串WebBrowser.Navigate()

它运作良好,但如果视频嵌入像VEVO这样的限制我无法看到它 https://www.youtube.com/embed/wfN4PVaOU5Q 在这里例证 有一件事告诉我它可能因为在这个网站上 http://codepen.io/Jebik/pen/ZLZQwX 嵌入式工作就像魅力...... 所以这可能是我没有得到这个限制的东西。

任何idéa和解决方案都很热情。 但我宁愿有一个合法的解决方案,比如“你必须注册你的域名并用https查询页面”而不是“你可以通过这种方法破解这种安全”

1 个答案:

答案 0 :(得分:0)

我发现了一种我不知道其原因的方法

我使用的服务器必须上传网页

<!DOCTYPE html>
<html>
  <body>
    <div id="player"></div>
    <script>
      var player;
      var body = document.body;
      var html = document.documentElement;
      var height = Math.max( body.scrollHeight, body.offsetHeight, 
                       html.clientHeight, html.scrollHeight, html.offsetHeight );
      var width = Math.max( body.scrollWidth, body.offsetWidth, 
                       html.clientWidth, html.scrollWidth, html.offsetWidth );
      window.onresize = resize;
      var tag = document.createElement('script');
      tag.src = "https://www.youtube.com/iframe_api";
      var firstScriptTag = document.getElementsByTagName('script')[0];
      firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
      function onYouTubeIframeAPIReady() 
      {
        player = new YT.Player('player', {
          height: height,
          width: width,
          playerVars: { 'autoplay': 1, 'controls': 0, 'showinfo': 0, 'enablejsapi':1, 'iv_load_policy':3, 'modestbranding':1, 'showinfo':0},
          videoId: '<?php echo $_GET["v"]; ?>',
          events: {
            'onReady': onPlayerReady
          }
        });
      }
      function resize()
      {
        height = Math.max( body.scrollHeight, body.offsetHeight, 
                       html.clientHeight, html.scrollHeight, html.offsetHeight );
        width = Math.max( body.scrollWidth, body.offsetWidth, 
                       html.clientWidth, html.scrollWidth, html.offsetWidth );
        if(player != null)
        {
          player.setSize(width, height);
        }
      }
      function onPlayerReady(event) {
        event.target.playVideo();
      }
      function playVideo() 
      {
        player.playVideo();
      }
      function pauseVideo() 
      {
        player.pauseVideo();
      }
    </script>
  </body>
</html>

必须从https访问网页 我不知道为什么 也许youtube使用证书来了解网站的真实位置(检查注册的位置而不是ip)

之后我将我的WebBrowser.NavigateToString改为WebBrowser.Navigate($"https://domain.fr/youtube.php?v={VideoCode}");

通过这种方式,我在WPF窗口中全屏显示了一个youtube播放器,我可以阅读大部分YouTube视频,例如VEVO限制版。

这已经解决,但如果有人知道为什么我很想知道