我正在尝试检查网址是否是有效的YouTube视频网址并从中获取YouTube视频ID,到目前为止我使用的是简单的javascript拆分功能以实现此目的,但是这有一些小的缺点,因为youtube有多个网址。
我一直在查看其他stackoverflow线程,但是它们只支持1个特定的URL,这不是我需要的。
我需要与所有这些网址匹配的内容:
HTTP(S)://www.youtu.be/videoID
HTTP(S)://www.youtube.com/watch V = VIDEOID
(以及脚本自动检测是否包含YouTube视频的任何其他短网址)
非常感谢浏览器快速/高效处理的任何想法!
答案 0 :(得分:48)
试试这个:
var url = "...";
var videoid = url.match(/(?:https?:\/{2})?(?:w{3}\.)?youtu(?:be)?\.(?:com|be)(?:\/watch\?v=|\/)([^\s&]+)/);
if(videoid != null) {
console.log("video id = ",videoid[1]);
} else {
console.log("The youtube url is not valid.");
}
见正则表达式:
/
(?:https?:\/{2})? // Optional protocol, if have, must be http:// or https://
(?:w{3}\.)? // Optional sub-domain, if have, must be www.
youtu(?:be)? // The domain. Match 'youtu' and optionally 'be'.
\.(?:com|be) // the domain-extension must be .com or .be
(?:\/watch\?v=|\/)([^\s&]+) //match the value of 'v' parameter in querystring from 'watch' directory OR after root directory, any non-space value.
/
答案 1 :(得分:8)
也许您应该查看Youtube API并尝试通过API解析URL来查看是否有办法获取videoID。
看看这篇SO帖子: Youtube API - Extract video ID
答案 2 :(得分:5)
这可能很快:
var url = 'http://www.youtu.be/543221';
//http://www.youtube.com/watch?v=SNfYz6Yw0W8&feature=g-all-esi would work also
var a = url.split("v=")[1];
a = a != undefined ? a : url.split("youtu.be/")[1];
b = a.split("&")[0];
变量c将具有您的ID。快。正则表达式更好......但更难阅读。我修改了我的代码以解决这两个问题。
答案 3 :(得分:2)
种类太多了:
http://youtu.be/NLqAF9hrVbY
http://www.youtube.com/embed/NLqAF9hrVbY
https://www.youtube.com/embed/NLqAF9hrVbY
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
http://www.youtube.com/watch?v=NLqAF9hrVbY
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
(来源:How do I find all YouTube video ids in a string using a regex?)最好的方法是限制输入数据。
祝你好运答案 4 :(得分:2)
试试这段代码
var url = "...";
var videoid = url.match((?:youtube(?:-nocookie)?\.com\/(?:[^\/\n\s]+\/\S+\/|(?:v|e(?:mbed)?)\/|\S*?[?&]v=)|youtu\.be\/)([a-zA-Z0-9_-]{11}));
if(videoid != null) {
console.log("video id = ",videoid[1]);
} else {
console.log("The youtube url is not valid.");
}
正则表达式来自 YouTube video ID regex
答案 5 :(得分:0)
您可以使用preg_match轻松完成此操作示例:
$url = "http://www.youtube.com/watch?v=YzOt12co4nk&feature=g-vrec";
preg_match('/v=([0-9a-zA-Z]+)/', $url, $matches);
$vid = $matches[1];
现在您的视频ID为:$ vid = YzOt12co4nk;
答案 6 :(得分:0)
我找到了一种不使用正则表达式的简单方法。
我做了一个函数来帮你:
function getLink(url){
fetch('www.youtube.com/oembed?url=' + url).then(res => {
var thumbnailUrl = res.thumbnail_url;
var id = thumbnail_url.split('vi/')[1].substring(0, 11);
return id;}
)
}
console.log(getLink(your_url));
// here replace 'your_url' with your specified youtube url.
所有这一切都是,它使用 youtube api 并将您的 url 作为参数传递,而 youtube 会处理 url 的类型,因此您不必担心。接下来的事情是,该函数然后从该 api 中获取 'thumbnail_url' 数据,然后相应地拆分缩略图的 url 以找到视频的 ID。