Adres URL filmu w serwisie YouTube można napotkać w różnych formatach:
- najnowszy krótki format:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (bezpieczne):
https://www.youtube.com/embed/NLqAF9hrVbY
- parametr obiektu:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- osadzenie obiektu:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- zegarek:
http://www.youtube.com/watch?v=NLqAF9hrVbY
- użytkownicy:
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
- ytscreeningroom:
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
- wszystko idzie!:
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
- dowolna / subdomena / też:
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
- więcej parametrów:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
- zapytanie może mieć kropkę:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
- domena nocookie:
http://www.youtube-nocookie.com
Oto funkcja PHP z skomentowanym wyrażeniem regularnym, która pasuje do każdego z tych formularzy URL i konwertuje je na linki (jeśli nie są już linkami):
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;
}
; // End $ YouTubeId.
A oto wersja JavaScript z dokładnie tym samym wyrażeniem regularnym (z usuniętymi komentarzami):
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>');
}
Uwagi:
- Część VIDEO_ID adresu URL jest ujęte w grupie jedyny przechwytywania:
$1
.
- Jeśli wiesz, że Twój tekst nie zawiera żadnych wstępnie połączonych adresów URL, możesz bezpiecznie usunąć negatywne twierdzenie wyprzedzające, które sprawdza ten warunek (stwierdzenie rozpoczynające się od komentarza: „Adres URL potwierdzenia nie jest wstępnie powiązany” ). To przyspieszy nieco podnieść wyrażenie regularne.
- Łańcuch zamiany można zmodyfikować w celu dopasowania. Ten, pod warunkiem powyżej po prostu tworzy link do rodzajowego
"http://www.youtube.com/watch?v=VIDEO_ID"
stylu URL i ustawia tekst link do: "YouTube link: VIDEO_ID"
.
Edycja 2011-07-05: Dodano -
łącznik do klasy znaków ID
Edycja 2011-07-17: Naprawiono wyrażenie regularne, które wykorzystywało pozostałą część (np. Zapytanie ) adresu URL po identyfikatorze YouTube. Dodano modyfikator 'i'
ignorowania wielkości liter . Zmieniono nazwę funkcji na camelCase. Ulepszony wstępnie połączony test wyprzedzenia.
Edycja 2011-07-27: Dodano nowe formaty „user” i „ytscreeningroom” do adresów URL YouTube.
Edycja 02.08.2011: Uproszczona / uogólniona obsługa nowych adresów URL „cokolwiek / coś / idzie” w YouTube.
Edycja 25.08.2011: Kilka modyfikacji:
- Dodano wersję JavaScript
linkifyYouTubeURLs()
funkcji:.
- Poprzednia wersja miała opcjonalną część schematu (protokołu HTTP) i dlatego pasowała do nieprawidłowych adresów URL. Wymagana część schematu.
- Poprzednia wersja używała
\b
zakotwiczenia granicy słowa wokół VIDEO_ID. Jednak to nie zadziała, jeśli VIDEO_ID zaczyna się lub kończy -
myślnikiem. Naprawiono tak, że obsługuje ten stan.
- Zmieniono wyrażenie VIDEO_ID tak, aby miało dokładnie 11 znaków.
- W poprzedniej wersji nie udało się wykluczyć wstępnie połączonych adresów URL, jeśli po VIDEO_ID występował ciąg zapytania. Poprawiono negatywną asercję wyprzedzającą, aby to naprawić.
- Dodano
+
i %
do ciągu zapytania pasującego do klasy znaków.
- Zmieniona wersja PHP regex ogranicznika od:
%
do a: ~
.
- Dodano sekcję „Notatki” z kilkoma przydatnymi notatkami.
Edytuj 2011-10-12: Część hosta adresu URL YouTube może teraz mieć dowolną subdomenę (nie tylko www.
).
Edycja 2012-05-01: Sekcja adresu URL konsumpcji może teraz zezwalać na „-”.
Edycja 23.08.2013: Dodano dodatkowy format dostarczony przez @Mei. (Część zapytania może mieć .
kropkę.
Edycja 30.11.2013: Dodano Format dodatkowe świadczone przez @CRONUS: youtube-nocookie.com
.
Edycja 2016-01-25: Naprawiono wyrażenie regularne obsługujące przypadki błędów dostarczane przez CRONUS.