CF7 - 数据库字段验证

CF7 - Database field validation

我想用数据库中的自定义列表验证我的 cf7 表单。因此,如果用户在不在我的列表中的字段中输入值,表单将无法通过验证。这是一个包含 60,000 个条目的长列表。

感谢您的帮助!

您可以使用 cf7 的自定义验证挂钩。您将需要执行以下操作:

add_filter( 'wpcf7_validate_email*', 'custom_email_confirmation_validation_filter', 20, 2 );

function custom_email_confirmation_validation_filter( $result, $tag ) {
$tag = new WPCF7_FormTag( $tag );

if ( 'your-email-confirm' == $tag->name ) {
    $your_email = isset( $_POST['your-email'] ) ? trim( $_POST['your-email'] ) : '';
    $your_email_confirm = isset( $_POST['your-email-confirm'] ) ? trim( $_POST['your-email-confirm'] ) : '';

    if ( $your_email != $your_email_confirm ) {
        $result->invalidate( $tag, "Are you sure this is the correct address?" );
    }
}

return $result;
}

这是电子邮件字段的基本自定义验证,您需要这样自定义:

add_filter( 'wpcf7_validate_email*', 'custom_field_validation', 20, 2 );

function custom_field_validation( $result, $tag ) {
$tag = new WPCF7_FormTag( $tag );

global $wpdb;
$searchTerm = $wpdb->get_row('select * from ' . $wpdb->prefix . 'name_of_table where name_of_field = "' . $_POST['given_value'] . '"');

if(!$searchTerm)
    $result->invalidate( $tag, "Value doesn't match" );

return $result;
}

如果您使用的是文本字段,也可以使用 wpcf7_validate_text 代替 wpcf7_validate_mail