Một vấn đề nhức nhối nhất khi chèn form vào website là bị bot nó auto spam quá. Mail spam từ cf7 suốt ngày luôn. Tức mà không làm gì được thì bài này sẽ giúp bạn chống/chặn luôn auto spam đó nhé
Chuyện là gần đây mình có 1 người inbox hỏi cách chặn spam cho cf7. Thấy bạn đó bảo đã cài akismet, recaptcha, wordfence, format sđt theo Việt Nam mà vẫn bị spam… may mắn cho bạn đó là mình sẵn có code tự làm nên chia sẻ luôn. Ấy vậy mà hiệu quả lắm nhé. Bạn đó bảo không còn thấy spam nữa… mừng quá và chia sẻ luôn cho mọi người cùng thử nha
Cách 1: Cách chống spam bằng field ẩn
Nguyên nhân: Đa số spam này là do bot auto spam. Nó cứ chèn đủ các field trong form và submit thôi. Kiểu submit auto luôn ý
Giải pháp: Nên mình nghĩ sao không làm 1 field ẩn. Sau đó check field đó nếu nó được nhập nội dung thì đích thị nó là SPAMER rồi đó chứ người thường không thể thấy field ẩn đó để điền được
Đến code: mình bắt tay vào code luôn nhé. do code sẵn nên các bạn chỉ cần copy code sau chèn vào wp-content/themes/{your-theme}/functions.php là được
/* * Chống spam cho contact form 7 * Author: levantoan.com * */ /*Thêm 1 field ẩn vào form cf7*/ add_filter('wpcf7_form_elements', 'devvn_check_spam_form_cf7'); function devvn_check_spam_form_cf7($html){ $html = '<div style="display: none"><p><span class="wpcf7-form-control-wrap" data-name="devvn"><input size="40" class="wpcf7-form-control wpcf7-text" aria-invalid="false" value="" type="text" name="devvn"></span></p></div>' . $html; return $html; } /*Kiểm tra form đó mà được nhập giá trị thì là spam*/ add_action('wpcf7_posted_data', 'devvn_check_spam_form_cf7_vaild'); function devvn_check_spam_form_cf7_vaild($posted_data) { $submission = WPCF7_Submission::get_instance(); if (!empty($posted_data['devvn'])) { $submission->set_status( 'spam' ); $submission->set_response( 'You are Spamer' ); } unset($posted_data['devvn']); return $posted_data; }
Giải thích một chút thì code trên sẽ thêm 1 field ẩn có name = devvn vào các form cf7 của bạn. Nếu field đó được nhập thì => spamer. Code được chia sẻ trên levantoan.com và nếu okie thì nhớ chia sẻ rộng rãi nha
Cách 2: Format số điện thoại theo định dạng Việt Nam
Với cách 1 phù hợp với tất cả các form và đặc biệt form dạng đăng ký email hoặc chỉ có 1 field đơn giản nào đó sẽ không ảnh hưởng tới thao tác người dùng. Và nếu cách 1 chưa chặn được spam cho form của bạn thì bạn có thể xem thêm cách 2 này nhé
Trong cách này mình sẽ format cho chuẩn số điện thoại theo Việt Nam là: số 0 đằng trước và có 9-10 số ở đằng sau số 0 nhé
Tất nhiên cách này chỉ phù hợp với 1 số trường hợp nhất định và bạn phải chú ý khi dùng
Ví dụ form của bạn ô số điện thoại như sau:
Thì code chèn vào wp-content/themes/{your-theme}/functions.php sẽ như sau
/* * Chống spam cho contact form 7 bằng định dạng số điện thoại * Author: levantoan.com * */ add_filter('wpcf7_validate_tel', 'devvn_custom_validate_sdt', 10, 2); add_filter('wpcf7_validate_tel*', 'devvn_custom_validate_sdt', 10, 2); function devvn_custom_validate_sdt($result, $tag) { $name = $tag->name; if ($name === 'your-tel') { $sdt = isset($_POST[$name]) ? wp_unslash($_POST[$name]) : ''; if (!preg_match('/^0([0-9]{9,10})+$/D', $sdt)) { $result->invalidate($tag, 'Số điện thoại không hợp lệ.'); } } return $result; }
Trong đoạn code trên bạn chú ý 3 chỗ cần chú ý là :
- wpcf7_validate_tel: chữ tel ở đây là loại field bạn dùng. Ở ví dụ dùng tel nhé. còn bạn dùng text thì nhập là text
- wpcf7_validate_tel*: chữ tel* ở đây là loại field bạn dùng và có bắt buộc.
- your-tel là tên field nhé. Đổi thành tên field của bạn cho đúng