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
我想用数据库中的自定义列表验证我的 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