php - wp_mail() + Ajax + ValidationEngine + $wpdb->插入

标签 php mysql ajax wordpress forms

我决定问这个问题,因为没有简单的答案。 我的 home.php 中有一个联系表单,如下所示:

HTML:

<form id="js-calculator" name="calculator" action="" method="post">
     <input type="email" name="email" id="email" placeholder="E-mail" />
     <input type="tel" name="phone" id="phone" placeholder="Phone" />
     <textarea name="message" id="message" placeholder="Message"></textarea>
     <label for="accept"><input class="" type="checkbox" id="accept" name="accept" /> I agree to terms and conditions</label>
     <button type="submit" id="send__btn">Wyślij wycenę</button></p>
</form>

JavaScript:

jQuery(document).ready(function ($) {
  $('#js-calculator').submit(function (e) {
    e.preventDefault();
    var $this = $(this);
    $.ajax({
      url: '<?php echo admin_url("admin-ajax.php") ?>',
      type: 'post',
      dataType: 'JSON',
      data: $this.serialize()
      }
    });
  });
});

functions.php 中的 PHP

  // Function to send emails
  function sendMail () {
    $subject = 'Automatic evaluation';
    $headers = 'From: My Website Contact Form <contact@mysite.com>';
    $send_to = "office@mysite.com, ". $_POST['email'];
    $subject = "Evaluation for ". $_POST['name'];
    $message = "Message from ".$_POST['message'];
  }
  add_action('wp_ajax_sendhtmlmail', 'sendMail');
  add_action('wp_ajax_nopriv_sendhtmlmail', 'sendMail');

  add_filter( 'wp_mail_content_type', 'set_content_type' );
  function set_content_type( $content_type ) {
    return 'text/html';
  }

  // Function to update DB
  function addCustomer(){
  global $wpdb;

  $phone = $_POST['phone'];
  $email = $_POST['email'];
  $accept = $_POST['accept'];

  if($wpdb->insert('customers',array(
    'phone'=>$phone,
    'email'=>$email,
    'accept'=>$accept
  ))===FALSE){
  echo "Error";
} else {
  $wpdb->insert_id;    
}
die();
}
add_action('wp_ajax_addCustomer', 'addCustomer');
add_action('wp_ajax_nopriv_addCustomer', 'addCustomer');

我想要达到的目标是: 1. 向客户和网站管理员发送一封 HTML 电子邮件, 2. 将客户详细信息添加到数据库,检查电子邮件是否存在, 3. 拥有安全的连接和数据流;

现在我不知道我做错了什么...任何帮助将不胜感激。

最佳答案

你已经快到了,有几件事:

在 JS ajax 调用中,您需要指定要调用的操作,这里是修改后的调用:

jQuery(document).ready(function ($) {
    $('#js-calculator').submit(function (e) {
      e.preventDefault();
      var $this = $(this);
      $.ajax({
        url: '<?php echo admin_url("admin-ajax.php?action=sendhtmlmail") ?>',
        type: 'post',
        dataType: 'JSON',
        data: $this.serialize()
        }
      });
    });
  });

现在,让我们看看 php 函数:

// Function to send emails
function sendMail () {
  $data = array(
    'email' = sanitize_email($_POST['email']),
    'name' = sanitize_text_field($_POST['name']),
    'message' = sanitize_text_field($_POST['message']),
  );
  $subject = 'Automatic evaluation;
  $headers = 'From: My Website Contact Form <contact@mysite.com>';
  $send_to = "office@mysite.com, ". $data['email'];
  $subject = "Evaluation for ". $data['name'];
  $message = "Message from ".$data['message'];
  wp_mail($send_to, $subject, $message, $headers);
  addCustomer($data);
  // TODO: Fill in this $response array with meaninfull data (check output from wp_mail and addCustomer)
  $response = array(
    'success' => true
  );
  wp_send_json($response);
}
add_action('wp_ajax_sendhtmlmail', 'sendMail');
add_action('wp_ajax_nopriv_sendhtmlmail', 'sendMail');

只是缺少 wp_mail 调用和输入清理,我删除了其他 ajax 调用,并让 sendMail 函数将数据传递给 addCustomer 函数。您会注意到 wp_send_json 调用,这是将响应发送到 JS。 https://codex.wordpress.org/Function_Reference/wp_send_json

现在让我们看看您的 addCustomer 函数:

// Function to update DB
function addCustomer($data){
  global $wpdb;

  $phone = $data['phone'];
  $email = $data['email'];
  $accept = $data['accept'];

  if($wpdb->insert('customers',array(
      'phone'=>$phone,
      'email'=>$email,
      'accept'=>$accept
    ))===FALSE){
    return false;
  } else {
    return $wpdb->insert_id;
  }
}

这里唯一改变的是返回,以便调用者知道它是否失败。

要处理用户的输入,请从 WordPress 和核心功能中检查此文档: https://codex.wordpress.org/Validating_Sanitizing_and_Escaping_User_Data

<小时/>

或者您可以一起使用以下插件:

使用方法如下:https://contactform7.com/save-submitted-messages-with-flamingo/

希望这对您有帮助! 问候,

P.S wordpress 问题更适合这里:https://wordpress.stackexchange.com/

关于php - wp_mail() + Ajax + ValidationEngine + $wpdb->插入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42225622/

相关文章:

php - 如何去除重音并将字母转换为 "plain"ASCII 字符?

php - 如何为 apache 守护进程设置 LD_LIBRARY_PATH?

php - 如何在 Laravel 5.6 中使用和自定义 HTML 电子邮件(不是 markdown)?

php - 设置 paypal 付款并将 HTML 表单数据发送到 mysql(但在处理付款之后)

java - JDBC 连接在执行 rs.next() 时挂起

javascript - 使用nodejs处理mysql连接

java - Spring MVC - 使用 Ajax 上传多部分文件(无法解析多部分 servlet 请求)

php - 编码成就系统的最佳方式

javascript - 通过 AJAX 加载新页面时保持 PHP 包含/需要

javascript - 来自控制台 : extract links from page, 的纯 javascript 模拟点击到另一个页面并执行相同操作