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

0

Когда я запускаю мой синтаксический анализ, он разбивает изображения, чтобы заменить URL-адреса ссылками через систему Oembed. Как я могу отредактировать это регулярное выражение, чтобы он не фиксировал ссылки в скобках 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);
}
Теги:
bbcode

1 ответ

-1

вы можете лишить текст

$text= strip_tags($text);

Ещё вопросы

Сообщество Overcoder
Наверх
Меню