Причини и решения за проблеми с шорткодовете в секцията за коментари в WordPress, които не се анализират

WordPress Въведете в секцията за коментари към статията [shortcode]Резултатът обаче показва само обикновен текст вместо желания ефект? Това всъщност е механизмът по подразбиране на WordPress. По-долу ще анализирам систематично причините и ще предоставя цялостно решение.

Защо секцията за коментари не поддържа шорткодове?

  • Ограничения по подразбиране
    От съображения за сигурност, WordPress не се стартира автоматично в секцията за коментари. do_shortcode()Това предотвратява произволното вмъкване на формуляри, скриптове или друго съдържание от страна на потребителите, което може да повлияе на сигурността на сайта.

  • Ограничен обхват на приложение
    Съкращението е предназначено главно за употреба в съдържанието на статии (the_contentТова включва джаджи или специфични плъгини, докато секцията за коментари не се поддържа по подразбиране.

  • Автоматична интерференция на форматирането
    Текстът на коментара ще бъде wpautop Добавяне автоматично <p><br> Тагове, които могат да нарушат синтаксичната структура на кратките кодове, правейки ги неразбираеми.

Причини и решения за проблеми с шорткодовете в секцията за коментари в WordPress, които не се анализират

Обработва се...

Как мога да активирам поддръжката на кратки кодове за коментари?

  • Активиране на шорткодове за коментари
    По темата functions.php Добавете следния код към вашия файл или плъгин за фрагмент от код:

    add_filter('comment_text', 'do_shortcode');
    

    Това ще накара секцията за коментари да използва кратки кодове.

  • Проверете дали плъгинът е активиран.
    Много шорткодове идват от плъгини (като Contact Form 7 и WooCommerce). Ако плъгинът не е активиран, шорткодовете няма да работят.

  • Избягвайте синтактични грешки
    Моля, потвърдете, че съкращението е написано правилно, например:

    [shortcode attribute="value"]内容[/shortcode]
    
  • Проверете за конфликти на теми или плъгини
    Преминете към темата по подразбиране (като Twenty Twenty-Five), деактивирайте всеки плъгин един по един, за да тествате и потвърдите дали има конфликти, които причиняват неправилна работа на шорткода.

  • Изтрий кеш-памет
    Когато използвате кеширащи плъгини или CDN мрежи, трябва да изчистите кеша след корекцията, за да видите ефекта.

Код за сигурно активиране на шорткодове в секцията за коментари

За да се избегнат рискове за сигурността, е възможно да functions.php Добавете следния пълен пример:

<?php
// 在评论区启用简码解析
add_filter('comment_text', 'do_shortcode');

// 限制允许的简码列表
function safe_comment_shortcodes($content) {
    // 定义允许的简码(加入 su_posts)
    $allowed_shortcodes = array('gallery', 'audio', 'video', 'contact-form-7', 'su_posts');

    // 遍历评论内容中的简码
    return preg_replace_callback('/\[(\w+)([^\]]*)\]/', function($matches) use ($allowed_shortcodes) {
        $shortcode = $matches[1];
        // 如果简码在允许列表中,正常解析
        if (in_array($shortcode, $allowed_shortcodes)) {
            return do_shortcode($matches[0]);
        }
        // 否则直接输出原始文本,避免执行
        return esc_html($matches[0]);
    }, $content);
}
add_filter('comment_text', 'safe_comment_shortcodes', 9);

описание на кода

  • Активиране на кратките кодовеПърви ред add_filter('comment_text', 'do_shortcode'); Активирайте поддръжката на кратки кодове в секцията за коментари.
  • Ограничени кратки кодове:мини $allowed_shortcodes Дефинициите на масиви позволяват съкращения, например gallery,audio,video,contact-form-7,su_posts.
  • Безопасно боравенеАко потребителят въведе кратък код, който не е в списъка с разрешени, кодът автоматично ще бъде екраниран в обикновен текст, за да се избегне изпълнението на потенциално опасни кратки кодове.

Най-добри практики

  • Разрешавайте само необходимите кратки кодовеНапример, в медийни презентации или формуляри, избягвайте използването на твърде много кратки кодове.
  • Редовно проверявайте за актуализации на плъгинитеУверете се, че плъгинът за шорткод е безопасен и надежден.
  • Комбиниране на плъгини за кеширане и защитаЗа да се избегне натиск върху производителността, причинен от рендирането на шорткодове.

Динамично подобрена версия: Интерфейс за настройки на бекенда (Търсене + Групиране + Съвети за фронтенда)

Ако искате по-голяма гъвкавост, можете да използвате следния подобрен код:

  • Автоматично изброяване на всички регистрирани кратки кодове(Включително тези, предоставени от плъгини).
  • Поддържа въвеждане на персонализирани кратки кодове(като ).
  • лента за търсенебързоПозициониранеСъкращение.
  • Групиран дисплейГрупирането по източник на плъгина го прави по-интуитивно.
  • Разрешения за ролиЩе бъдат анализирани само кратките кодове в коментарите на администраторите; кратките кодове в коментарите на обикновени потребители ще показват съобщението „Този ​​кратък код е достъпен само за администратори“.
<?php
// 添加后台菜单
function cwl_shortcode_settings_menu() {
    add_options_page(
        '评论简码设置',
        '评论简码设置',
        'manage_options',
        'cwl-shortcode-settings',
        'cwl_shortcode_settings_page'
    );
}
add_action('admin_menu', 'cwl_shortcode_settings_menu');

// 注册设置
function cwl_register_shortcode_settings() {
    register_setting('cwl_shortcode_settings_group', 'cwl_allowed_shortcodes');
    register_setting('cwl_shortcode_settings_group', 'cwl_custom_shortcodes');
}
add_action('admin_init', 'cwl_register_shortcode_settings');

// 设置页面内容
function cwl_shortcode_settings_page() {
    global $shortcode_tags;
    $allowed = get_option('cwl_allowed_shortcodes', array());
    $custom  = get_option('cwl_custom_shortcodes', array());

    ?>
    <div class="wrap">
        <h1>评论区简码设置</h1>
        <form method="post" action="options.php">
            <?php settings_fields('cwl_shortcode_settings_group'); ?>

            <h2>搜索简码</h2>
            <input type="text" id="cwl_shortcode_search" placeholder="输入简码关键字..." style="width:300px;">

            <h2>已注册简码(按插件来源分组)</h2>
            <p>勾选允许在评论区执行的简码:</p>
            <div id="cwl_shortcode_list">
                <?php
                // 按插件来源分组
                $groups = array();
                foreach ($shortcode_tags as $tag => $callback) {
                    $source = is_array($callback) ? get_class($callback[0]) : (is_object($callback) ? get_class($callback) : '主题/未知来源');
                    $groups[$source][] = $tag;
                }

                foreach ($groups as $source => $tags) {
                    echo "<h3>" . esc_html($source) . "</h3>";
                    foreach ($tags as $tag) {
                        ?>
                        <label class="cwl_shortcode_item">
                            <input type="checkbox" name="cwl_allowed_shortcodes[]" value="<?php echo esc_attr($tag); ?>" <?php checked(in_array($tag, $allowed)); ?>>
                            <?php echo esc_html($tag); ?>
                        </label><br>
                        <?php
                    }
                }
                ?>
            </div>

            <h2>自定义简码</h2>
            <p>输入额外允许的简码(用逗号分隔):</p>
            <textarea name="cwl_custom_shortcodes" rows="3" cols="50"><?php echo esc_textarea(implode(',', (array)$custom)); ?></textarea>

            <?php submit_button(); ?>
        </form>
    </div>

    <script>
    // 简码搜索功能
    document.getElementById('cwl_shortcode_search').addEventListener('keyup', function() {
        var keyword = this.value.toLowerCase();
        document.querySelectorAll('.cwl_shortcode_item').forEach(function(item) {
            var text = item.textContent.toLowerCase();
            item.style.display = text.indexOf(keyword) > -1 ? '' : 'none';
        });
    });
    </script>
    <?php
}

// 评论区简码过滤(结合角色权限 + 前端提示)
function cwl_safe_comment_shortcodes($content) {
    $allowed_shortcodes = get_option('cwl_allowed_shortcodes', array());
    $custom_shortcodes  = get_option('cwl_custom_shortcodes', array());
    $allowed_shortcodes = array_merge($allowed_shortcodes, (array)$custom_shortcodes);

    return preg_replace_callback('/\[(\w+)([^\]]*)\]/', function($matches) use ($allowed_shortcodes) {
        $shortcode = $matches[1];
        // 管理员可解析简码
        if (current_user_can('manage_options')) {
            if (in_array($shortcode, $allowed_shortcodes)) {
                return do_shortcode($matches[0]);
            }
            return esc_html($matches[0]);
        } else {
            // 普通用户提示信息
            if (in_array($shortcode, $allowed_shortcodes)) {
                return '<span style="color:red;">此简码仅管理员可用</span>';
            }
            return esc_html($matches[0]);
        }
    }, $content);
}
add_filter('comment_text', 'cwl_safe_comment_shortcodes', 9);

总结

Секциите за коментари в WordPress не анализират съкращенията по подразбиране от съображения за сигурност и производителност. Вместо това можете да използвате [инструмента за анализиране]. functions.php Добавете филтър, за да активирате шорткодове и да го комбинирате със сигурност.

Блог на Hope Chen Weiliang ( https://www.chenweiliang.com/ Статията „Причини и решения за проблеми с парсинга на шорткодове в секцията за коментари в WordPress“, споделена тук, може да ви бъде полезна.

Добре дошли да споделите връзката към тази статия:https://www.chenweiliang.com/cwl-34132.html

За да отключите още скрити трикове🔑, заповядайте в нашия Telegram канал!

Споделете и харесайте, ако ви харесва! Вашите споделяния и харесвания са нашата постоянна мотивация!

 

发表 评论

Вашият имейл адрес няма да бъде публикуван. Използват се задължителните полета * Етикет

Преминете към Top