Um URL de vídeo do YouTube pode ser encontrado em vários formatos:
- formato curto mais recente:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe (seguro):
https://www.youtube.com/embed/NLqAF9hrVbY
- parâmetro de objeto:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- incorporação de objetos:
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
- ver:
http://www.youtube.com/watch?v=NLqAF9hrVbY
- Comercial:
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
- ytscreeningroom:
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
- qualquer coisa serve!:
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
- qualquer / subdomínio / também:
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
- mais params:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
- a consulta pode ter um ponto:
http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
- domínio nocookie:
http://www.youtube-nocookie.com
Aqui está uma função PHP com uma regex comentada que corresponde a cada um desses formulários de URL e os converte em links (se ainda não forem links):
// 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;
}
; // Fim de $ YouTubeId.
E aqui está uma versão JavaScript com exatamente a mesma regex (com comentários removidos):
// 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>');
}
Notas:
- A parte VIDEO_ID da URL é capturado no grupo único e captura:
$1
.
- Se você sabe que seu texto não contém URLs pré-vinculados, pode remover com segurança a afirmação antecipada negativa que testa essa condição (a afirmação que começa com o comentário: "Afirmar que o URL não está pré-vinculado." ) Isso irá acelerar até o regex um pouco.
- A string de substituição pode ser modificada para se adequar. O fornecido acima simplesmente cria um link para o genérico
"http://www.youtube.com/watch?v=VIDEO_ID"
URL estilo e define o texto link: "YouTube link: VIDEO_ID"
.
Editar 05-07-2011:-
Hífen adicionado à classe ID char
Editar 2011-07-17: Corrigido regex para consumir qualquer parte restante (por exemplo, consulta ) de URL após o ID do YouTube. Adicionado modificador 'i'
ignore-case . Função renomeada para camelCase. Teste antecipado pré-vinculado aprimorado.
Editar 27/07/2011: Novos formatos de "usuário" e "ytscreeningroom" adicionados aos URLs do YouTube.
Editar 02-08-2011: simplificado / generalizado para lidar com novos URLs "qualquer / coisa / vai" do YouTube.
Editar 25/08/2011: Várias modificações:
- Adicionada uma versão Javascript de:
linkifyYouTubeURLs()
function.
- A versão anterior tinha a parte do esquema (protocolo HTTP) opcional e, portanto, corresponderia a URLs inválidos. Tornou a parte do esquema necessária.
- A versão anterior usava a
\b
palavra âncora de limite em torno do VIDEO_ID. No entanto, isso não funcionará se o VIDEO_ID começar ou terminar com um -
travessão. Corrigido para lidar com essa condição.
- Alterada a expressão VIDEO_ID para que tenha exatamente 11 caracteres.
- A versão anterior não conseguiu excluir URLs pré-vinculados se eles tivessem uma string de consulta seguindo o VIDEO_ID. Melhorou a afirmação de antecipação negativa para corrigir isso.
- Adicionado
+
e %
à classe de caracteres correspondente à string de consulta.
- Changed versão PHP delimitador regex de:
%
um: ~
.
- Adicionada uma seção "Notas" com algumas notas úteis.
Editar 12/10/2011: a parte do host do URL do YouTube agora pode ter qualquer subdomínio (não apenas www.
).
Editar 01-05-2012: A seção consumir URL agora pode permitir '-'.
Editar 2013-08-23: Adicionado formato adicional fornecido por @Mei. (A parte da consulta pode ter um .
ponto.
Editar 2013/11/30: Adicionado formato adicional fornecida pelo @CRONUS: youtube-nocookie.com
.
Editar 25/01/2016: Regex corrigido para lidar com casos de erro fornecidos pelo CRONUS.