L'URL di un video di YouTube può essere rilevato in una varietà di formati:
- ultimo breve formato:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (sicuro):
https://www.youtube.com/embed/NLqAF9hrVbY
- parametro oggetto:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- oggetto incorporato:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- orologio:
http://www.youtube.com/watch?v=NLqAF9hrVbY
- utenti:
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
- ytscreeningroom:
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
- qualsiasi / cosa / va !:
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
- any / subdomain / too:
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
- più parametri:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
- la query può contenere un punto:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
- dominio nocookie:
http://www.youtube-nocookie.com
Ecco una funzione PHP con un'espressione regolare commentata che corrisponde a ciascuno di questi moduli URL e li converte in collegamenti (se non sono già collegamenti):
// 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;
}
; // End $ YouTubeId.
Ed ecco una versione JavaScript con la stessa identica regex (con commenti rimossi):
// 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>');
}
Appunti:
- La porzione VIDEO_ID dell'URL viene catturato nel gruppo unico bloccaggio:
$1
.
- Se sai che il tuo testo non contiene URL precollegati, puoi rimuovere in sicurezza l'asserzione lookahead negativa che verifica questa condizione (l'asserzione che inizia con il commento: "L'URL dell'affermazione non è pre-collegato" ) . un po 'la regex.
- La stringa di sostituzione può essere modificata per adattarla. L'unica condizione precedente crea semplicemente un link al generico
"http://www.youtube.com/watch?v=VIDEO_ID"
URL stile e imposta il testo del link a: "YouTube link: VIDEO_ID"
.
Modifica 2011-07-05: aggiunto -
trattino alla classe di caratteri ID
Modifica 2011-07-17: corretta regex per consumare qualsiasi parte rimanente (ad es. Query ) dell'URL dopo l'ID YouTube. Aggiunto modificatore 'i'
ignora maiuscole e minuscole . Funzione rinominata in camelCase. Test di lookahead pre-collegato migliorato.
Modifica 27/07/2011: aggiunti nuovi formati "utente" e "ytscreeningroom" degli URL di YouTube.
Modifica 2011-08-02: semplificato / generalizzato per gestire nuovi URL di YouTube "qualsiasi / cosa / va".
Modifica 2011-08-25: Diverse modifiche:
- Aggiunta una versione Javascript di:
linkifyYouTubeURLs()
function.
- La versione precedente aveva la parte dello schema (protocollo HTTP) opzionale e quindi corrispondeva a URL non validi. Ha reso necessaria la parte dello schema.
- La versione precedente utilizzava la
\b
parola ancoraggio di confine attorno a VIDEO_ID. Tuttavia, questo non funzionerà se VIDEO_ID inizia o finisce con un -
trattino. Risolto in modo che gestisca questa condizione.
- Modificata l'espressione VIDEO_ID in modo che debba contenere esattamente 11 caratteri.
- La versione precedente non era in grado di escludere gli URL pre-collegati se avevano una stringa di query dopo VIDEO_ID. Migliorata l'asserzione di lookahead negativo per risolvere questo problema.
- Aggiunto
+
e %
alla stringa di query corrispondente alla classe di caratteri.
- Cambiato versione di PHP espressione regolare delimitatore da:
%
a: ~
.
- Aggiunta una sezione "Note" con alcune note utili.
Modifica 2011-10-12: la parte host dell'URL di YouTube può ora avere qualsiasi sottodominio (non solo www.
).
Modifica 01/05/2012: la sezione dell'URL di consumo può ora consentire l'uso di "-".
Modifica 2013-08-23: aggiunto formato aggiuntivo fornito da @Mei. (La parte della query potrebbe avere un .
punto.
Modifica 2013/11/30: Aggiunta formato supplementare fornita da @CRONUS: youtube-nocookie.com
.
Modifica 25-01-2016: corretta regex per gestire i casi di errore forniti da CRONUS.