0

我正在构建一个自定义 wordpress 插件,它将在主页上显示 contactform7 表单。

工作流程:

1.用户使用contactform7创建表单并复制简码

2.用户在插件的设置表单中输入值/简码

3.插件使用 $_POST['the-shortcode'] 捕获值/短代码

4.插件将值/简码保存在 wp_options 数据库中

5.插件 echo out 或 do_shortcode 显示 values/shortcode/CF7 表格

我的问题:每当我通过插件的设置表单保存联系表 7 简码时

[contact-form-7 id="4" title="联系表格 1"]

它变成了这样:(注意有一些 \ )

[contact-form-7 id=\"4\" title=\"联系表格1\"]

我尝试使用 esc_attr() 但它不起作用。

esc_attr($_POST['the-shortcode'])

如何将联系表格 7 短代码保存到 wp_options 数据库中,以便我可以回显 do_shortcode('theshortcode') ?

这是插件设置表单的代码:

<?php

global $options;
$cform_shortcode = esc_attr($_POST['cform_shortcode']);
$options['cform_shortcode'] = $cform_shortcode;
update_option('plugin_databasename_db', $options);
$options = get_option('plugin_databasename_db');
$cform_shortcode = $options['cform_shortcode'];
?>

<table>
    <tr>
    <td scope="row"><label for="tablecell">
    Contact Form ShortCode
    </label></td>
    <td scope="row"><label for="tablecell">
    <textarea name="cform_shortcode" id="" cols="80" rows="3"><?php if (isset($cform_shortcode)) {echo $cform_shortcode;} else {'';} ?></textarea>
    </label></td>
    </tr>
</table>

这是前端的代码:

<?php 
global $options; 
$options = get_option('plugin_databasename_db');

if ( isset( $options['cform_title'] ) && isset( $options['cform_shortcode'] ) ){ ?>
<p class="wpic-strong"><?php echo $options['cform_title']?></p>
<div class="list-group-item-video">
  <?php echo do_shortcode($options['cform_shortcode']);	?>
</div>
<br/>
<?php	
} else {
'';
}			
?>

4

1 回答 1

3

暂时替换这个:

<?php echo do_shortcode($options['cform_shortcode']);   ?>

有了这个:

<?php echo do_shortcode('[contact-form-7 id="4" title="Contact form 1"]');  ?>

只是看看它是否有效(那样)。

[编辑] 保存的值可能包含\,所以试试这个:

<?php echo do_shortcode( wp_unslash($options['cform_shortcode']) ); ?>

[编辑#2]在那种情况下(即&quot;事物),这是因为您在esc_attr将用户的输入保存到数据库时使用了该功能。

所以使用sanitize_text_field(去除 HTML 标签)而不是esc_attr(不去除 HTML 标签,但将它们转换为 HTML 实体):

$cform_shortcode = sanitize_text_field( wp_unslash($_POST['cform_shortcode']) );

然后通过后端表单重新保存选项(即 Contact Form 7 Shortcode)。之后,看看这个do_shortcode东西是否在前端工作。

于 2018-01-15T06:12:10.237 回答