我实际上正在开发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查询页面”而不是“你可以通过这种方法破解这种安全”
答案 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限制版。
这已经解决,但如果有人知道为什么我很想知道