自定义wordpress联系表单

时间:2013-08-07 17:21:23

标签: php wordpress

我正在尝试制作自定义的wordpress联系表单。我到目前为止:

我的联系表格本身的功能:

<?php
if( isset( $_POST['submitted'] ) ) {
  //response generation function

  $response = "";

  //function to generate response
  function my_contact_form_generate_response($type, $message){

    global $response;

    if($type == "success") $response = "<div class='success'>{$message}</div>";
    else $response = "<div class='error'>{$message}</div>";

  }

  //response messages
  $not_human       = "Human verification incorrect.";
  $missing_content = "Please supply all information.";
  $email_invalid   = "Email Address Invalid.";
  $message_unsent  = "Message was not sent. Try Again.";
  $message_sent    = "Thanks! Your message has been sent.";

  //user posted variables
  $name = $_POST['message_name'];
  $email = $_POST['message_email'];
  $message = $_POST['message_text'];
  $human = $_POST['message_human'];

  //php mailer variables
  $to = get_option('admin_email');
  $subject = "Someone sent a message from ".get_bloginfo('name');
  $headers = 'From: '. $email . "\r\n" .
    'Reply-To: ' . $email . "\r\n";

  if(!$human == 0){
    if($human != 2) my_contact_form_generate_response("error", $not_human); //not human!
    else {

      //validate email
      if(!filter_var($email, FILTER_VALIDATE_EMAIL))
        my_contact_form_generate_response("error", $email_invalid);
      else //email is valid
      {
        //validate presence of name and message
        if(empty($name) || empty($message)){
          my_contact_form_generate_response("error", $missing_content);
        }
        else //ready to go!
        {
          $sent = wp_mail($to, $subject, strip_tags($message), $headers);
          if($sent) my_contact_form_generate_response("success", $message_sent); //message sent!
          else my_contact_form_generate_response("error", $message_unsent); //message wasn't sent
        }
      }
    }
  }
  else if ($_POST['submitted']) my_contact_form_generate_response("error", $missing_content);
}
?>

其次:

<div id="respond">
          <?php echo $response; ?>
          <form action="<?php the_permalink(); ?>" method="post">
            <p><label for="name">Name: <span>*</span> <br><input type="text" name="message_name" value="<?php echo esc_attr($_POST['message_name']); ?>"></label></p>
            <p><label for="message_email">Email: <span>*</span> <br><input type="text" name="message_email" value="<?php echo esc_attr($_POST['message_email']); ?>"></label></p>
            <p><label for="message_text">Message: <span>*</span> <br><textarea type="text" name="message_text"><?php echo esc_textarea($_POST['message_text']); ?></textarea></label></p>
            <p><label for="message_human">Human Verification: <span>*</span> <br><input type="text" style="width: 60px;" name="message_human"> + 3 = 5</label></p>
            <input type="hidden" name="submitted" value="1">
            <p><input type="submit"></p>
          </form>
        </div>

这很好用,但它很基本。我不想使用插件,因为它们看起来都非常臃肿而且非常混乱。也许我只看了不好的选择。无论如何,我想知道在向管理员发送电子邮件时是否可以编辑消息的格式。目前,我得到的是没有其他信息的消息,如人名,电子邮件..

我使用它做出了错误的选择吗?

将通过表单发送的任何电子邮件格式化为格式如下:

Sender:Joe Blogs

电子邮件:joe@blogs.com

消息:我爱你。

2 个答案:

答案 0 :(得分:1)

为什么不简单地扩展当前的$message变量?

//user posted variables
$name = $_POST['message_name'];
$email = $_POST['message_email'];
$message = $_POST['message_text'];
$human = $_POST['message_human'];

// this is the new part
$temp_message = $message;
$message = 'Sender: '.$name.'<br/>';
$message .= 'Email: '.$email.'<br/>';
$message .= 'Human: '.$human.'<br/>';
$message .= 'Message: '.$temp_message;

答案 1 :(得分:1)

如果它快速,轻巧,并且做你想要的(在你扭结之后),那就太好了。我可以看到它比插件更快,更轻松。

我担心的是,一些比较流行的联系表单插件(如Contact Form 7)已针对可用性,漏洞利用等进行了现场测试,并已添加代码来处理这些情况。

如果你自己滚动,你可能(很可能会?)被某些东西击中,如果你因为表格中的漏洞利用而最终发送了大量垃圾邮件,那就是你。

不要劝阻你的努力 - 而不是我能看到你所做的事情有什么不妥! - 但只是一种直觉。