javascript - 网站联系表格收不到消息

标签 javascript php html contact-form

非常新的 html 和网站开发人员,不确定为什么我当前的联系框不起作用。我正在托管我自己的网站,当我尝试发送时,我会收到一条已发送的消息响应,但从未收到电子邮件。

我尚未消除因使用多个电子邮件地址发送和接收而损坏的电子邮件托管,但无法找到问题的根源。

参见下面的相关代码

main.js

// Contact form
var form = $('#main-contact-form');
form.submit(function (event) {
    event.preventDefault();
    var form_status = $('<div class="form_status"></div>');
    $.ajax({
        url: $(this).attr('action'),
        beforeSend: function () {
            form.prepend(form_status.html('<p><i class="fa fa-spinner fa-spin"></i> Email is sending...</p>').fadeIn());
        }
    }).done(function (data) {
        form_status.html('<p class="text-success">Thank you for contact us. As early as possible  we will contact you</p>').delay(3000).fadeOut();
    });
});

sendemail.php

<?php
$name       = @trim(stripslashes($_POST['name'])); 
$from       = @trim(stripslashes($_POST['email'])); 
$subject    = @trim(stripslashes($_POST['name']));  
$message    = @trim(stripslashes($_POST['message'])); 
$to         = '\\myemailaddress//';

$headers   = array();
$headers[] = "MIME-Version: 1.0";
$headers[] = "Content-type: text/plain; charset=iso-8859-1";
$headers[] = "From: {$name} <{$from}>";
$headers[] = "Reply-To: <{$from}>";
$headers[] = "Subject: {$subject}";
$headers[] = "X-Mailer: PHP/".phpversion();

mail($to, $subject, $message, $headers);

die;

index.html

<div class="col-md-8 col-sm-12">
     <div class="contact-form bottom">
           <h2>Send a message</h2>
                <form id="main-contact-form" name="contact-form" method="post" action="sendemail.php">
                     <div class="form-group">
                         <input type="text" name="name" class="form-control" required="required" placeholder="Name">
                        </div>
                        <div class="form-group">
                            <input type="email" name="email" class="form-control" required="required" placeholder="Email Id">
                        </div>
                        <div class="form-group">
                            <textarea name="message" id="message" required="required" class="form-control" rows="8" placeholder="Your text here"></textarea>
                        </div>
                        <div class="form-group">
                            <input type="submit" name="submit" class="btn btn-submit" value="Submit">
                       </div>
               </form>
       </div>
</div>

提前谢谢您!

最佳答案

下一个问题是您没有使用 ajax 发送任何数据。使用 $(formSelector).serialize() 简化了数据收集

$.ajax({
    url: $(this).attr('action'),
    //serialize form data and include it with request
    data: form.serialize(),
    beforeSend: function () {
        ...
    }
}).done(function (data) {
    ....
});

目前,如果您在 php 中执行 print_r($_POST);,您会看到它是空的

关于javascript - 网站联系表格收不到消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34833903/

相关文章:

php - 如何防止 PHP 中的 SQL 注入(inject)?

Javascript自动计算表格输入框中的字符并在表格数量输入框中输入结果?

javascript - 在多行javascript中传播html

javascript - 谷歌可视化折线图缺少 Y 轴

javascript - 页面加载时未加载 Angular-ui-router 状态

php - 错误 : localhost redirected you too many times

jquery - Zurb Foundation Accordion 嵌套在 Accordion 内部

javascript - 检索数组JS中的所有对象

javascript - 跟踪网站访问者的浏览习惯

php - 将数据存储到数据库的更短方法