2016-08-03 16 views
0

Ich habe ein Problem mit meinem AJAX-Kontaktformular, alles, was ich versuchte, schlug fehl. Ich bekomme immer den Fehler von der jQuery Part if(html==0).AJAX-Kontaktformular funktioniert NICHT

Jemand bitte helfen, kann das Problem nicht finden. Vielen Dank!

jQuery Teil: action.js

$(function() { 

    /* EMAIL VALIDATOR */ 
    function isEmail(email) { 
     var pattern = new RegExp(/^(("[\w-+\s]+")|([\w-+]+(?:\.[\w-+]+)*)|("[\w-+\s]+")([\w-+]+(?:\.[\w-+]+)*))(@((?:[\w-+]+\.)*\w[\w-+]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][\d]\.|1[\d]{2}\.|[\d]{1,2}\.))((25[0-5]|2[0-4][\d]|1[\d]{2}|[\d]{1,2})\.){2}(25[0-5]|2[0-4][\d]|1[\d]{2}|[\d]{1,2})\]?$)/i); 
     return pattern.test(email); 
    } 

    /* CONTACT */ 
    $('#contact-submit').click(function() { 
     var firstname = $('#contact-firstname').val(); 
     if(!firstname.trim()) { 
      $('#contact-firstname').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie Ihren Vornamen ein!</span>'); 
      return false; 
     } 
     var lastname = $('#contact-lastname').val(); 
     if(!lastname.trim()) { 
      $('#contact-lastname').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie Ihren Nachnamen ein!</span>'); 
      return false; 
     } 
     var email = $('#contact-email').val(); 
     if(!email.trim()) { 
      $('#contact-email').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie Ihre E-Mail ein!</span>'); 
      return false; 
     } else { 
      if(!isEmail(email)) { 
       $('#contact-email').focus(); 
       $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie eine g&uuml;ltige E-Mailadresse ein!</span>'); 
       return false; 
      } 
     } 
     var phone1 = $('#contact-phone1').val(); 
     if(!phone1.trim()) { 
      $('#contact-phone1').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie Ihre Landesvorwahl ein!</span>'); 
      return false; 
     } 
     var phone2 = $('#contact-phone2').val(); 
     if(!phone2.trim()) { 
     $('#contact-phone2').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie Ihre Telefonnummer ein!</span>'); 
      return false; 
     } 
     var phone = phone1+' (0) '+phone2; 
     var subject = $('#contact-subject').val(); 
     if(!subject.trim()) { 
      $('#contact-subject').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie einen Betreff ein!</span>'); 
      return false; 
     } 
     var message = $('#contact-message').val(); 
     if(!message.trim()) { 
      $('#contact-message').focus(); 
      $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Bitte geben Sie eine Nachricht ein!</span>'); 
      return false; 
     } 

     $.ajax({ 
      type: 'POST', 
      url: 'action.php', 
      data: 'contact=1&firstname='+firstname+'&lastname='+lastname+'&email='+email+'&phone='+phone+'&subject='+subject+'&message='+message, 
      dataType: 'html', 
      success: function(html) { 
       if(html==0) { 
        $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Nachricht konnte nicht gesendet werden!</span>'); 
       } else if(html==1) { 
        $('#contact-result').html('Danke f&uuml;r Ihre Nachricht!'); 
       } else { 
        alert('Fehler beim Senden!'); 
       } 
      } 
     }); 
     return false; 
    }); 
}); 

PHP-Teil: action.php

<? if($_POST['contact']) { 
    $contactEmail = '[email protected]'; 

    $firstname = $_POST['firstname']; 
    $lastname = $_POST['lastname']; 
    $email  = $_POST['email']; 
    $phone  = $_POST['phone']; 
    $subject = $_POST['subject']; 
    $message = $_POST['message']; 

    $mailSubject = 'KONTAKTANFRAGE '.$subject; 

    $mailMessage = $message.'\r\n'.'\r\n'; 
    $mailMessage .= 'Vorname: '.$firstname.'\r\n'; 
    $mailMessage .= 'Nachname: '.$lastname.'\r\n'; 
    $mailMessage .= 'E-Mail: '.$email.'\r\n'; 
    $mailMessage .= 'Telefonnummer: '.$phone; 

    $mailHeader = 'MIME-Version: 1.0'.'\r\n'; 
    $mailHeader .= 'Content-type:text/html;charset=UTF-8'.'\r\n'; 
    $mailHeader .= 'From: Kontkatformular'.'\r\n'; 
    $mailHeader .= 'Reply-To: '.$email.'\r\n'; 

    $sendMail = mail($contactEmail, $mailSubject, $mailMessage, $mailHeader); 

    if($sendMail) { 
     echo 1; 
    } else { 
     echo 0; 
    } 
} ?> 
+0

PHP-Mail-Funktion funktioniert nicht, wenn Netzverbindung es off.Please zu überprüfen ist, und sagen Sie uns – Debojyoti

+0

ich es online –

+0

Prüfung vielleicht der Fehler zurückzuführen ist, ist in HTML ein Schlüsselwort.Bitte überprüfen Sie es mit einem anderen Variablennamen – Debojyoti

Antwort

0

Versuchen Sie, Ihre initilization Daten Ich würde

$.ajax({ 
      type: 'POST', 
      url: 'action.php', 
      data: {contact: 1, firstname:firstname,lastname:lastname, email:email, phone:phone, subject:subject, message:message}, 
      dataType: 'html', 
      success: function(html) { 
       if(html==0) { 
        $('#contact-result').html('<span class="error"><i class="fa fa-exclamation-triangle fa-fw"></i>&nbsp;Nachricht konnte nicht gesendet werden!</span>'); 
       } else if(html==1) { 
        $('#contact-result').html('Danke f&uuml;r Ihre Nachricht!'); 
       } else { 
        alert('Fehler beim Senden!'); 
       } 
      } 
     }); 
+0

erhalten Sie den gleichen Fehler mit diesem –

+0

GOT IT! Ich musste nur eine Absender-E-Mail-Adresse in den Mail-Header setzen. Danke für Ihre Hilfe! –

0

Änderungen vorschlagen Sie die Verwendung von Json, um die Daten zu analysieren.

Also Ihr JavaScript-Code würde wie folgt aussehen:

$.post('action.php', 
{ 
    'contact' : 1, 
    'firstname' : firstname, 
    'lastname' : lastname 
}).done(function(response) 
{ 
    var json = JSON.parse(response); 

    if(json.status == false) 
     /* do something */ 

    else if(json.status == true) 
     /* do something */ 

    else /* This might never happen.. */ 
     /* do something else */ 
}); 

Und Ihr PHP-Code würde wie folgt aussehen:

$status = $sendMail == TRUE ? TRUE : FALSE; 

echo json_encode(array 
(
    'status' => $status 
)); 
+0

Dies funktioniert nicht, dies gibt mir den Alarmfehler (die letzte sonst Bedingung) –

+0

Nicht möglich. Die $ status-Variable erhält nur 'TRUE' oder' FALSE', daher haben Sie sonst wo in Ihrem Code Fehler. – Linesofcode

+0

ERHALTEN SIE ES! Ich musste nur eine Absender-E-Mail-Adresse in den Mail-Header setzen. Danke für Ihre Hilfe! –

0

Ihre Header müssen mit Zeilenumbrüchen beenden. Einfache Anführungszeichen werden nur die tatsächlichen Zeichen \r\n ausgeben, während doppelte Anführungszeichen sie in neue Zeilen umwandeln. Ihre E-Mail wahrscheinlich versagt wegen schlechten Header, so passen sie wie folgt aus:

$mailHeader = 'MIME-Version: 1.0'."\r\n"; 
$mailHeader .= 'Content-type:text/html;charset=UTF-8'."\r\n"; 
$mailHeader .= 'From: Kontkatformular'."\r\n"; 
$mailHeader .= 'Reply-To: '.$email."\r\n"; 

Wenn es immer noch nicht die E-Mail zu senden, werden Sie bei Ihrem Mail-Server-Logs schauen müssen, um zu sehen, wo das Problem liegen.

+0

Immer noch das Gleiche, aber danke für Ihre Hilfe. –

+0

ERHALTEN SIE ES! Ich musste nur eine Absender-E-Mail-Adresse in den Mail-Header setzen. Danke für Ihre Hilfe! –

0

, dass die Lösung ist:

$mailHeader = 'MIME-Version: 1.0'."\r\n"; 
$mailHeader .= 'Content-type:text/html;charset=UTF-8'."\r\n"; 
$mailHeader .= 'From: Kontkatformular <[email protected]>'."\r\n"; 
$mailHeader .= 'Reply-To: '.$email."\r\n";