Regex найти URL-адреса, но не BBCode Urls?

Когда я запускаю свой анализ, он разбивает изображения, заменяя URL-адреса ссылками через систему Oembed. Как я могу отредактировать этот Regex, чтобы он не захватывал ссылки в скобках BBCode?

    // Parse bbcodes before link parsing for image support
$text = self::parseBBCodes($text);

$text = preg_replace_callback('/(https?:\/\/.*?)(\s|$)/i', function ($match) use (&$oembedCount, &$maxOembedCount) {

Я сейчас попробовал

$text = preg_replace_callback('/(?<!\])(https?:\/\/.*?)(\s|$)(?!\[)/i', function ($match) use (&$oembedCount, &$maxOembedCount) {

Что, кажется, работает, но изображения не конвертер. Хотя обычный bbcode есть.

Функция BBCode

/**
* Parse BBCode
*
* @param string $text contains the text with BBCode to be parsed
*/
public static function parseBBcodes($text)
{

// BBcode array
$find = array(
'~\[b\](.*?)\[/b\]~s',
'~\[i\](.*?)\[/i\]~s',
'~\[u\](.*?)\[/u\]~s',
'~\[quote\](.*?)\[/quote\]~s',
'~\[size=(.*?)\](.*?)\[/size\]~s',
'~\[color=(.*?)\](.*?)\[/color\]~s',
'~\[img\](https?://.*?\.(?:jpg|jpeg|gif|png|bmp))\[/img\]~s'
);

// HTML tags to replace BBcode
$replace = array(
'<b>$1</b>',
'<i>$1</i>',
'<span style="text-decoration:underline;">$1</span>',
'<pre>$1</'.'pre>',
'<span style="font-size:$1px;">$2</span>',
'<span style="color:$1;">$2</span>',
'<img src="$1" alt="" />'
);

// Replacing the BBcodes with corresponding HTML tags
return preg_replace($find,$replace,$text);
}

0

Решение

Вы можете удалить свой текст

$text= strip_tags($text);
-1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]