【发布时间】:2017-09-13 00:13:55
【问题描述】:
我想使用蜜罐而不是 recaptcha 来处理垃圾邮件。我正在运行 WordPress。通常,我会为此使用 Gravity 表单,但是,我没有开发此站点,他们使用碳字段来填充表单字段。
我在下面的 js 中需要一个条件,即 if $robotest !="" echo "this is spam" 否则提交表单。我的蜜罐表单字段是robotest (var $robotest = $this.find(['[name="robotest"]']);)。
这是提交表单的全部代码:
$('.form-suite form').on('submit', function(e) {
e.preventDefault();
var is_valid = true;
var data_to_send = {};
var $this = $(this);
console.log('FORM SUBMITTED!!!!');
console.log('ap test');
console.log($('#event_dates').val());
console.log(grecaptcha);
var $team_artist_event = $this.find('[name="team-artist-event"]');
var $booking_event = $this.find('[name="game"]');
var $first_name = $this.find('[name="fname"]');
var $last_name = $this.find('[name="lname"]');
var $company = $this.find('[name="company"]');
var $email = $this.find('[name="email"]');
var $phone = $this.find('[name="phone"]');
var $contact_method = $this.find('[name="contact-method"]');
var $comments = $this.find('[name="comments"]');
var $sell_suite = $this.find(['[name="sell_suite"]']);
var $corporate_outings = $this.find(['[name="corporate_outings"]']);
var $event_dates = $this.find(['[name="event_dates"]']);
var $how_many = $this.find(['[name="how_many"]']);
var $robotest = $this.find(['[name="robotest"]']);
console.log('AARON HI dates:' + $event_dates.val());
$this.find('.required').each(function() {
$(this).attr('style', 'background-color: #ddd;');
var field_value = $(this).val();
if (field_value == '') {
$(this).attr('style', 'background-color: rgba(255, 40, 40, 0.25) !important;');
is_valid = false;
}
});
//var captcha = grecaptcha.getResponse();
//if (captcha == '') {
//is_valid = false;
//$('.captcha').attr('style', 'background-color: rgba(255, 40, 40, 0.25) //!important;');
//}
var email_regex = /[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$/;
if (!email_regex.test($email.val())) {
$email.attr('style', 'background-color: rgba(255, 40, 40, 0.25) !important;');
is_valid = false;
}
if (is_valid) {
data_to_send.team_artist_event = $team_artist_event.val();
data_to_send.booking_event = $booking_event.val();
data_to_send.first_name = $first_name.val();
data_to_send.last_name = $last_name.val();
data_to_send.company = $company.val();
data_to_send.email = $email.val();
data_to_send.phone = $phone.val();
data_to_send.contact_method = $contact_method.val();
data_to_send.comments = $comments.val();
data_to_send.sell_suite = $sell_suite.val();
data_to_send.corporate_outings = $corporate_outings.val();
data_to_send.action = 'booking_form';
data_to_send.event_dates = $('#event_dates').val();
data_to_send.how_many = $('#how_many').val();
$.ajax({
url: ajax_object.ajax_url,
data: data_to_send,
method: 'POST',
dataType: 'json',
success: function(data) {
if (data.status == 'OK') {
console.log('GA send');
ga('send', {
'hitType': 'pageview',
'page': '/form-submit/team' // Virtual page (aka, does not actually exist) that you can now track in GA Goals as a destination page.
});
ga('send', 'event', 'Forms', 'submitted', 'Team Form');
window.location.href = '/thank-you.php';
//$('.personal-info, .event-info').hide();
//$(' .event-info').before('<h2 class="form-success-msg">' + data.message + '</h2>');
}
},
});
}
});
【问题讨论】:
-
除了您要问的...您的
email_regex过于严格,将排除许多许多 有效的电子邮件地址,包括来自较新(较长)TLD 的所有内容像.museum以及 @ 左侧的[a-z0-9._%+-]+之外的许多合法字符 -- 参见 How to Find or Validate an Email Address -
感谢您指出这一点。蜜罐问题有什么想法吗?
-
所以如果我已经清楚了,
$robotest应该始终为空,除非机器人找到并填写它。然后对非空的测试意味着 is_valid 应该是错误的,并且可以在您将验证码测试注释掉的地方进行该测试...if ($robotest.val().length > 0) { is_valid = false; }
标签: javascript wordpress forms