Une URL de la vidéo YouTube peut être rencontré dans une variété de formats:
- dernier court-format:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (sécurisé):
https://www.youtube.com/embed/NLqAF9hrVbY
- objet param:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- objet intégrer:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- watch:
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/chose/va!:
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
- tout/sous-domaine/trop:
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
- plus params:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
- requête peut avoir point:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
- nocookie de domaine:
http://www.youtube-nocookie.com
Voici une fonction PHP avec une commenté l'expression rationnelle qui correspond à chacun de ces URL formes et les convertit les liens (si ils ne sont pas des liens déjà):
// Linkify youtube URLs which are not already links.
function linkifyYouTubeURLs($text) {
$text = preg_replace('~
# 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;
}
Et Voici une version JavaScript avec exactement le même regex (avec 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>');
}
Notes:
- Le VIDEO_ID partie de l'URL qui est capturé dans le seul et unique groupe de capture:
$1
.
- Si vous savez que votre texte ne contient pas de pré-Url liés, vous pouvez supprimer en toute sécurité l'anticipation négatif affirmation qui teste cette condition (L'affirmation début avec le commentaire: "Affirmer l'URL n'est pas pré-lié.") Cela permettra d'accélérer la regex quelque peu.
- La chaîne de remplacement peut être modifié pour répondre. Celle prévue ci-dessus crée simplement un lien vers le générique
"http://www.youtube.com/watch?v=VIDEO_ID"
URL de style et définit le texte du lien: "YouTube link: VIDEO_ID"
.
Edit 2011-07-05: Ajouté -
trait d'union pour l'ID de classe char
Edit 2011-07-17: Fixe regex pour consommer toute partie restante (par exemple, la requête) de l'URL suivante ID YouTube. Ajouté 'i'
ignorer cas de modification. Renommé fonction de camelCase. Amélioration de la pré-lié d'anticipation de test.
Edit 2011-07-27: Ajout de nouvelles "utilisateur" et "ytscreeningroom" formats de YouTube Url.
Edit 2011-08-02: Simplifié/généralisées à gérer de nouvelles "tout/chose/va" YouTube Url.
Edit 2011-08-25: Plusieurs modifications:
- Ajout d'une version Javascript de:
linkifyYouTubeURLs()
fonction.
- La version précédente avait le schéma (protocole HTTP) la partie facultative et donc correspondre à des Url non valide. Faites le schéma de la partie requise.
- La version précédente a utilisé l'
\b
limite de mot d'ancrage autour de la VIDEO_ID. Toutefois, cela ne fonctionnera pas si le VIDEO_ID commence ou se termine avec un -
tableau de bord. Corrigé de sorte qu'il gère cette condition.
- Changé la VIDEO_ID expression qui doit être exactement de 11 caractères.
- La version précédente a échoué pour exclure les Url liés s'ils avaient une chaîne de requête à la suite de la VIDEO_ID. L'amélioration de l'anticipation négatif affirmation de résoudre ce problème.
- Ajouté
+
et %
à la classe de caractères correspondant de la chaîne de requête.
- Changé la version de PHP regex délimiteur de:
%
d'un: ~
.
- Ajout d'une section "Notes" avec un peu de pratique notes.
Edit 2011-10-12: Youtube URL de l'hôte de la partie, peuvent maintenant avoir tout sous-domaine (et pas seulement www.
).
Edit 2012-05-01: Le consommer URL de l'article peut maintenant permettre '-'.
Edit 2013-08-23: Ajout format supplémentaires fournis par @Mei. (La partie requête peut avoir un .
dot.
Edit 2013-11-30: Ajout format supplémentaires fournis par @CRONOS: youtube-nocookie.com
.