Как вы используете аутентификацию с gmail для контактной формы PHP? - PullRequest
0 голосов
/ 08 апреля 2011

Это код, который у меня работает; Однако я хочу включить способ проверки подлинности SMTP с использованием моей учетной записи Gmail, но я не могу понять ... помочь?

<?php

if(isset($_POST['email'])) {

    $email_to = "jfk003@lvc.edu";
    $email_subject = "Website Inquire";


    function died($error) {
        echo "We are very sorry, but there were error(s) found with the form you submitted. ";
        echo "These errors appear below.<br /><br />";
        echo $error."<br /><br />";
        echo "Please go back and fix these errors.<br /><br />";
        die();
    }

    // validation expected data exists
    if(!isset($_POST['first_name']) ||
        !isset($_POST['last_name']) ||
        !isset($_POST['email']) ||
        !isset($_POST['telephone']) ||
        !isset($_POST['comments'])) {
        died('We are sorry, but there appears to be a problem with the form you submitted.');       
    }

    $first_name = $_POST['first_name']; // required
    $last_name = $_POST['last_name']; // required
    $email_from = $_POST['email']; // required
    $telephone = $_POST['telephone']; // not required
    $comments = $_POST['comments']; // required

    $error_message = "";
    $email_exp = "/^[^0-9][A-z0-9_]+([.][A-z0-9_]+)*[@][A-z0-9_]+([.][A-z0-9_]+)*[.][A-z]{2,4}$/";
  if (preg_match($email_exp, $email_from)) {
    echo "Email address is valid.";
  }
  else 

    {
        echo "Email address is <u>not</u> valid.";
  }
    $string_exp = "/^[a-zA-Z .'-]+$/";
  if(!preg_match($string_exp,$first_name)) {
    $error_message .= 'The First Name you entered does not appear to be valid.<br />';
  }
  if(!preg_match($string_exp,$last_name)) {
    $error_message .= 'The Last Name you entered does not appear to be valid.<br />';
  }
  if(strlen($comments) < 2) {
    $error_message .= 'The Comments you entered do not appear to be valid.<br />';
  }
  if(strlen($error_message) > 0) {
    died($error_message);
  }
    $email_message = "Form details below.\n\n";

    function clean_string($string) {
      $bad = array("content-type","bcc:","to:","cc:","href");
      return str_replace($bad,"",$string);
    }

    $email_message .= "First Name: ".clean_string($first_name)."\n";
    $email_message .= "Last Name: ".clean_string($last_name)."\n";
    $email_message .= "Email: ".clean_string($email_from)."\n";
    $email_message .= "Telephone: ".clean_string($telephone)."\n";
    $email_message .= "Comments: ".clean_string($comments)."\n";



$headers = 'From: '.$email_from."\n".
'Reply-To: '.$email_from."\n".
'X-Mailer: PHP/'.phpversion();

@mail($email_to, $email_subject, $email_message, $headers);

} 

?>

Ответы [ 4 ]

0 голосов
/ 02 января 2014
This is a complete working example.    
<?php
    // this is for troubleshooting errors 
    // set the 1 to 0 to turn off (must set to 0 when in production mode or when you run this live 
    error_reporting(E_ALL);
    ini_set('display_errors', '1');
?><?php
    if(isset($_POST['email'])) {
        $email_to       = $_POST['email'];
        $email_subject  = "E-mail from website visitor.";

        // try adding a useful/relevent message to errors output to users
        function died($error) {
            echo "We are very sorry, but there were error(s) found with the form you submitted:\n\t ";
            echo $error."<br /><br />";
            echo "Please go back and fix these errors.<br /><br />";
            die();
        }

        // validation expected data exists
        // since all post are submit, check if they are empty or equal to an empty string
        if(isset($_POST['email'])){
            if($_POST['email'] == "" || $_POST['first_name'] == "" || $_POST['last_name'] == "" || $_POST['telephone'] == "" || $_POST['comments'] == ""){
                died('Please fill out the entire form');
            }
        }

        $first_name = $_POST['first_name']; // required
        $last_name  = $_POST['last_name']; // required
        $email_from = $_POST['email']; // required
        $telephone  = $_POST['telephone']; // not required
        $comments   = $_POST['comments']; // required

        $error_message = "";
        $email_exp = '/^[A-Za-z0-9._%-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}$/';
        $string_exp = "/^[A-Za-z .'-]+$/";

        if(!preg_match($email_exp,$email_from))
            $error_message .= 'The Email Address you entered does not appear to be valid.<br />';
        if(!preg_match($string_exp,$first_name))
            $error_message .= 'The First Name you entered does not appear to be valid.<br />';
        if(!preg_match($string_exp,$last_name))
            $error_message .= 'The Last Name you entered does not appear to be valid.<br />';
        if(strlen($comments) < 2)
            $error_message .= 'The Message you entered do not appear to be valid.<br />';
        if(strlen($error_message) > 0)
            died($error_message);
        $email_message = "Form details below.\n\n";

        function clean_string($string) {
            $bad = array("content-type","bcc:","to:","cc:","href");
            return str_replace($bad,"",$string);
        }
        $email_message .= "First Name: ".clean_string($first_name)."\n";
        $email_message .= "Last Name: ".clean_string($last_name)."\n";
        $email_message .= "Email: ".clean_string($email_from)."\n";
        $email_message .= "Telephone: ".clean_string($telephone)."\n";
        $email_message .= "Comments: ".clean_string($comments)."\n";

        // create email headers
        // changed up your email a bit
        $headers = "From: $email_from\n";
        $headers.= "MIME-Version: 1.0\n";
        $headers .= "Content-type: text/html; charset=iso-8859-1\n";
        mail($email_to, $email_subject, $email_message, $headers);
        header('Location: http://www.cnn.com');
        exit();
    }
?>
<form action="<?php echo $_SERVER['PHP_SELF'] ?>" method="post">
    Firstname:<br>
    <input type="text" name="first_name"><br>
    Lastname:<br>
    <input type="text" name="last_name"><br>
    Email:<br>
    <input type="text" name="email"><br>
    Phone Number:<br>
    <input type="text" name="telephone"><br>
    Comments:<br>
    <input type="textarea" name="comments"><br><br>
    <input type="submit" value="Submit">
</form>
0 голосов
/ 08 апреля 2011

Вы можете использовать PHPMailer http://sourceforge.net/projects/phpmailer/,, вот как вы отправляете электронную почту, используя GMail, но HTML и CSS здесь вам мало помогут.

function email($to, $subject, $body){
    require_once("class.phpmailer.php");

    $mail = new PHPMailer();

    $mail->SMTPAuth = true;
    $mail->SMTPSecure = "ssl";
    $mail->Host = "smtp.gmail.com";
    $mail->Port = 465;
    $mail->Username = "name@example";
    $mail->Password = "123456";

    $mail->SetFrom("name@example.com", "Name Example");

    $mail->Subject = $subject;
    $mail->Body = $body;

    $mail->AddAddress($to);
    $mail->Send();
    unset($mail);
}
0 голосов
/ 04 августа 2013

Я думаю, используя gmail;Google измените там методы аутентификации, я смог успешно пройти аутентификацию, выполнив сначала этот шаг: Ссылка на видео Это для двухэтапного процесса, чтобы разрешить внешнему приложению

вам потребуется сгенерировать пароль приложения..

, затем используйте этот пароль для своего приложения PHP.

0 голосов
/ 08 апреля 2011

Вы хотите использовать современную почтовую библиотеку PHP, например SwiftMailer , которая поддерживает аутентификацию SMTP.

Ознакомьтесь с инструкциями Google о том, какие серверы использовать и документы SwiftMailer на отправка почты на SMTP-сервер SSL / TLS и отправка почты с именем пользователя /combo password .

При обновлении кода для использования SwiftMailer вам следует отказаться от мерзости регулярного выражения проверки электронной почты, которое исключает многочисленные полностью действительные локальные части и домены.Правильная оболочка здравомыслия, навязанная построением сообщения с использованием вызовов методов , позаботится о большинстве других потенциальных проблем в вашем коде, таких как эта странная функция clean_string - она ​​вам не понадобится(и я не уверен, что вы думаете, что он делает здесь, но это не делает строку более безопасной).

...