Une URL de vidéo YouTube peut être rencontrée dans divers formats:
- dernier format court:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (sécurisé):
https://www.youtube.com/embed/NLqAF9hrVbY
- paramètre d'objet:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- incorporer l'objet:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- regarder:
http://www.youtube.com/watch?v=NLqAF9hrVbY
- utilisateurs:
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
- ytscreeningroom:
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
- tout va!:
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
- tout / sous-domaine / aussi:
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
- plus de paramètres:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
- la requête peut avoir un point:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
- domaine nocookie:
http://www.youtube-nocookie.com
Voici une fonction PHP avec une expression régulière commentée qui correspond à chacune de ces formes d'URL et les convertit en liens (si ce ne sont pas déjà des liens):
// 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;
}
; // Fin de $ YouTubeId.
Et voici une version JavaScript avec exactement le même regex (avec les commentaires supprimés):
// 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>');
}
Remarques:
- La partie VIDEO_ID de l'URL est capturée dans le groupe de capture unique:
$1
.
- Si vous savez que votre texte ne contient aucune URL pré-liée, vous pouvez supprimer en toute sécurité l'assertion de recherche négative qui teste cette condition (L'assertion commençant par le commentaire: "Assert URL is not pre-linked." ) Cela accélérera un peu le regex.
- La chaîne de remplacement peut être modifiée en conséquence. Celui fourni ci - dessus crée simplement un lien vers l'générique
"http://www.youtube.com/watch?v=VIDEO_ID"
URL de style et définit le texte de lien vers: "YouTube link: VIDEO_ID"
.
Edit 2011-07-05: Ajout d'un -
trait d'union à la classe de caractères ID
Edit 2011-07-17: Correction de l'expression régulière pour consommer toute partie restante (par exemple, requête ) de l'URL suivant l'ID YouTube. Ajout du modificateur Ignorer la 'i'
casse . Fonction renommée camelCase. Test d'anticipation pré-lié amélioré.
Edit 2011-07-27: Ajout de nouveaux formats "utilisateur" et "ytscreeningroom" pour les URL YouTube.
Edit 02/08/2011: simplifié / généralisé pour gérer les nouvelles URL YouTube "tout / chose / va".
Edit 2011-08-25: Plusieurs modifications:
- Ajout d'une version Javascript de:
linkifyYouTubeURLs()
function.
- La version précédente avait la partie schéma (protocole HTTP) facultative et correspondrait donc aux URL invalides. Fait la partie du régime requise.
- La version précédente utilisait l'
\b
ancre de limite de mot autour du VIDEO_ID. Cependant, cela ne fonctionnera pas si le VIDEO_ID commence ou se termine par un -
tiret. Corrigé pour qu'il gère cette condition.
- L'expression VIDEO_ID a été modifiée pour qu'elle contienne exactement 11 caractères.
- La version précédente n'a pas réussi à exclure les URL pré-liées si elles avaient une chaîne de requête après VIDEO_ID. Amélioration de l'assertion d'anticipation négative pour résoudre ce problème.
- Ajouté
+
et %
à la chaîne de requête correspondant à la classe de caractères.
- Changement version PHP delimiter regex de:
%
à: ~
.
- Ajout d'une section «Notes» avec quelques notes pratiques.
Edit 2011-10-12: la partie hôte d'URL YouTube peut désormais avoir n'importe quel sous-domaine (pas seulement www.
).
Edit 2012-05-01: La section URL de consommation peut désormais autoriser «-».
Edit 2013-08-23: Ajout d'un format supplémentaire fourni par @Mei. (La partie requête peut avoir un .
point.
Modifier 30/11/2013: Ajout Format supplémentaire fourni par @CRONUS: youtube-nocookie.com
.
Edit 2016-01-25: Correction de l'expression régulière pour gérer les cas d'erreur fournis par CRONUS.