URL-адреса видео YouTube могут быть представлены в различных форматах:
- последний короткий формат:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (безопасный):
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
- ytscreeningroom:
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
- домен nocookie:
http://www.youtube-nocookie.com
Вот функция PHP с закомментированным регулярным выражением, которое соответствует каждой из этих форм URL и преобразует их в ссылки (если они еще не являются ссылками):
function linkifyYouTubeURLs($text) {
$text = preg_replace('~(?#!js YouTubeId Rev:20160125_1800)
# Match non-linked youtube URL in the wild. (Rev:20130823)
https?:// # Required scheme. Either http or https.
(?:[0-9A-Z-]+\.)? # Optional subdomain.
(?: # Group host alternatives.
youtu\.be/ # Either youtu.be,
| youtube # or youtube.com or
(?:-nocookie)? # youtube-nocookie.com
\.com # followed by
\S*? # Allow anything up to VIDEO_ID,
[^\w\s-] # but char before ID is non-ID char.
) # End host alternatives.
([\w-]{11}) # $1: VIDEO_ID is exactly 11 chars.
(?=[^\w-]|$) # Assert next char is non-ID or EOS.
(?! # Assert URL is not pre-linked.
[?=&+%\w.-]* # Allow URL (query) remainder.
(?: # Group pre-linked alternatives.
[\'"][^<>]*> # Either inside a start tag,
| </a> # or inside <a> element text contents.
) # End recognized pre-linked alts.
) # End negative lookahead assertion.
[?=&+%\w.-]* # Consume any URL (query) remainder.
~ix', '<a href="http://www.youtube.com/watch?v=$1">YouTube link: $1</a>',
$text);
return $text;
}
; // Конец $ YouTubeId.
А вот версия JavaScript с таким же регулярным выражением (без комментариев):
function linkifyYouTubeURLs(text) {
var re = /https?:\/\/(?:[0-9A-Z-]+\.)?(?:youtu\.be\/|youtube(?:-nocookie)?\.com\S*?[^\w\s-])([\w-]{11})(?=[^\w-]|$)(?![?=&+%\w.-]*(?:['"][^<>]*>|<\/a>))[?=&+%\w.-]*/ig;
return text.replace(re,
'<a href="http://www.youtube.com/watch?v=$1">YouTube link: $1</a>');
}
Примечания:
- VIDEO_ID часть URL захватывается в группе один и только захвата:
$1
.
- Если вы знаете, что ваш текст не содержит никаких предварительно связанных URL-адресов, вы можете безопасно удалить утверждение отрицательного просмотра вперед, которое проверяет это условие (утверждение, начинающееся с комментария: « Утвержденный URL-адрес не имеет предварительной ссылки» ). Это ускорит работу. немного увеличить регулярное выражение.
- Строку замены можно изменить по своему усмотрению. Один Приведенные выше просто создает ссылку на общий
"http://www.youtube.com/watch?v=VIDEO_ID"
URL стиля и задает текст ссылки на: "YouTube link: VIDEO_ID"
.
Изменить 2011-07-05: добавлен -
дефис в класс идентификатора char
Изменить 2011-07-17: исправлено регулярное выражение для использования любой оставшейся части (например, запроса ) URL-адреса после идентификатора YouTube. Добавлен модификатор 'i'
игнорирования регистра . Функция переименована в camelCase. Улучшенный предварительный просмотр вперед с привязкой.
Edit 2011-07-27: Добавлены новые форматы "user" и "ytscreeningroom" URL-адресов YouTube.
Редактировать 2011-08-02: Упрощено / обобщено для обработки новых URL-адресов YouTube "все, что угодно / идет".
Изменить 2011-08-25: несколько модификаций:
- Добавлена Javascript-версия:
linkifyYouTubeURLs()
function.
- В предыдущей версии часть схемы (протокол HTTP) была необязательной и, следовательно, соответствовала недопустимым URL-адресам. Сделал часть схемы необходимой.
- Предыдущая версия использовала
\b
привязку границы слова вокруг VIDEO_ID. Однако это не сработает, если VIDEO_ID начинается или заканчивается -
тире. Исправлено, так что он обрабатывает это условие.
- Изменено выражение VIDEO_ID, теперь оно должно состоять ровно из 11 символов.
- Предыдущая версия не могла исключить предварительно связанные URL-адреса, если у них была строка запроса, следующая за VIDEO_ID. Улучшено утверждение отрицательного просмотра вперед, чтобы исправить это.
- Добавлен
+
и %
в строку запроса сопоставления класса символов.
- Измененный PHP версия регулярных выражений Ограничитель из:
%
к: ~
.
- Добавлен раздел «Заметки» с некоторыми удобными заметками.
Изменить 2011-10-12: часть хоста URL-адреса YouTube теперь может иметь любой субдомен (не только www.
).
Изменить 2012-05-01: раздел URL-адреса потребления теперь может допускать '-'.
Изменить 2013-08-23: добавлен дополнительный формат, предоставленный @Mei. (В части запроса может быть .
точка.
Редактирование 2013-11-30: Добавлен дополнительный формат обеспечивается @CRONUS: youtube-nocookie.com
.
Изменить 2016-01-25: исправлено регулярное выражение для обработки случая ошибки, предоставленной CRONUS.