Eine YouTube-Video-URL kann in verschiedenen Formaten gefunden werden:
- aktuelles Kurzformat:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (sicher):
https://www.youtube.com/embed/NLqAF9hrVbY
- Objektparameter:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- Objekteinbettung:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- sehen:
http://www.youtube.com/watch?v=NLqAF9hrVbY
- Benutzer:
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
- ytscreeningroom:
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
- alles geht!:
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
- jede / Subdomain / auch:
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
- Weitere Parameter:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
- Abfrage kann Punkt haben:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
- Nocookie-Domain:
http://www.youtube-nocookie.com
Hier ist eine PHP-Funktion mit einem kommentierten regulären Ausdruck, der mit jedem dieser URL-Formulare übereinstimmt und sie in Links konvertiert (sofern es sich nicht bereits um Links handelt):
// Linkify youtube URLs which are not already links.
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 beenden.
Und hier ist eine JavaScript-Version mit genau demselben regulären Ausdruck (mit entfernten Kommentaren):
// Linkify youtube URLs which are not already links.
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>');
}
Anmerkungen:
- Der VIDEO_ID-Teil der URL wird in der einzigen Erfassungsgruppe erfasst :
$1
.
- Wenn Sie wissen, dass Ihr Text keine vorverknüpften URLs enthält, können Sie die negative Lookahead-Behauptung, die diese Bedingung testet, sicher entfernen. (Die Behauptung beginnt mit dem Kommentar: "URL bestätigen ist nicht vorverknüpft." ) Dies beschleunigt sich den regulären Ausdruck etwas erhöhen.
- Die Ersetzungszeichenfolge kann entsprechend geändert werden. Die oben angegebene erstellt einfach einen Link zur
"http://www.youtube.com/watch?v=VIDEO_ID"
URL im generischen Stil und setzt den Linktext auf : "YouTube link: VIDEO_ID"
.
Edit 2011-07-05:-
Bindestrich zur ID- Zeichenklasse hinzugefügt
Edit 2011-07-17: Regex behoben , um alle verbleibenden Teile (z. B. Abfragen ) der URL nach der YouTube-ID zu verbrauchen . Modifikator für 'i'
Groß- und Kleinschreibung hinzugefügt . Funktion in camelCase umbenannt. Verbesserter vorverknüpfter Lookahead-Test.
Bearbeiten 2011-07-27: Neue Formate "Benutzer" und "ytscreeningroom" von YouTube-URLs hinzugefügt.
Edit 2011-08-02: Vereinfacht / verallgemeinert, um neue YouTube-URLs "any / thing / goes" zu verarbeiten.
Edit 2011-08-25: Mehrere Änderungen:
- Eine Javascript-Version von:
linkifyYouTubeURLs()
function wurde hinzugefügt .
- In früheren Versionen war der Teil des Schemas (HTTP-Protokoll) optional und stimmte daher mit ungültigen URLs überein. Das Schema Teil erforderlich gemacht.
- In der vorherigen Version wurde
\b
der Wortbegrenzungsanker um die VIDEO_ID verwendet. Dies funktioniert jedoch nicht, wenn die VIDEO_ID mit einem -
Bindestrich beginnt oder endet . Behoben, dass es diese Bedingung behandelt.
- Der Ausdruck VIDEO_ID wurde so geändert, dass er genau 11 Zeichen lang sein muss.
- In der vorherigen Version konnten vorverknüpfte URLs nicht ausgeschlossen werden, wenn nach der VIDEO_ID eine Abfragezeichenfolge vorhanden war. Die negative Lookahead-Behauptung wurde verbessert, um dies zu beheben.
- Hinzugefügt
+
und %
zu Zeichenklasse passenden Query - String.
- Der Regex-Begrenzer für die PHP-Version wurde von:
%
in: geändert ~
.
- Es wurde ein Abschnitt "Notizen" mit einigen praktischen Notizen hinzugefügt.
Bearbeiten 2011-10-12: Der YouTube-URL-Host-Teil kann jetzt eine beliebige Subdomain haben (nicht nur www.
).
Edit 2012-05-01: Der Abschnitt zum Konsumieren von URLs kann jetzt '-' zulassen.
Bearbeiten 23.08.2013: Zusätzliches Format von @Mei hinzugefügt. (Der Abfrageteil kann einen .
Punkt haben.
Bearbeiten 30.11.2013: Zusätzliches Format von @CRONUS hinzugefügt : youtube-nocookie.com
.
Edit 2016-01-25: Regex behoben , um den von CRONUS bereitgestellten Fehlerfall zu behandeln.