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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | /* * Chống spam cho contact form 7 * Share by: GiuseArt.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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | /* * Chống spam cho contact form 7 bằng định dạng số điện thoại * Share by: giuseart.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; } |
Cách 3: Thêm dạng câu hỏi – trả lời vào form
Nếu qua 2 cách trên mà bạn vẫn bị spam thì.. cách này chắc chắn sẽ triệt để luôn nè nhưng nó cũng hơi phiền cho người dùng nhé
Giải pháp: thêm 1 danh sách câu hỏi đơn giản để khi khách điền form sẽ nhập câu trả lời vào đó. Nếu đúng thì mới cho submit form. Tất nhiên là thêm vài câu đơn giản hết mức có thể thôi. Dạng như 1 + một bằng mấy? hoặc 2 + một bằng mấy? thế thì bố bot cũng không biết đâu
Cách làm: cái này thì không cần code thêm mà dùng luôn field quiz của cf7 nhé. Trong ví dụ mình thêm 3 câu hỏi thôi. Bạn có thể thêm câu hỏi khác và nhiều hơn nữa nha
Sửa form mà bạn muốn chống spam => đặt chuột vào vị trí muốn hiển thị field trong form của bạn => ấn vào Câu hỏi như hình dưới
Bên ngoài sẽ hiển thị như sau:
Ưu điểm:
- Chắc chắn chống spam triệt để luôn
Hạn chế:
- Gây khó cho người dùng khó tính
- Form phải thêm 1 field
Vậy thôi trên đây là 3 cách chống spam mà mình muốn chia sẻ với các bạn. Chúc các bạn chặn được mấy cái bot spam khó chịu đó nha.
Nguồn tham khảo: //levantoan.com/
Chia sẻ bài viết: