По умолчанию почта Laravel не работает

Я пытаюсь отправить электронное письмо активации при регистрации. У меня есть простой сайт laravel с регистрацией и аутентификацией. При регистрации отсутствуют ошибки, и данные хранятся правильно, однако письмо никогда не отправляется. Пробовал несколько разных примеров, но у меня такая же проблема.

Это мой конфигурационный файл mail.php

<?php return array( /* |-------------------------------------------------------------------------- | Mail Driver |-------------------------------------------------------------------------- | | Laravel supports both SMTP and PHP's "mail" function as drivers for the | sending of e-mail. You may specify which one you're using throughout | your application here. By default, Laravel is setup for SMTP mail. | | Supported: "smtp", "mail", "sendmail" | */ 'driver' => 'smtp', /* |-------------------------------------------------------------------------- | SMTP Host Address |-------------------------------------------------------------------------- | | Here you may provide the host address of the SMTP server used by your | applications. A default option is provided that is compatible with | the Postmark mail service, which will provide reliable delivery. | */ 'host' => 'smtp.mailgun.org', /* |-------------------------------------------------------------------------- | SMTP Host Port |-------------------------------------------------------------------------- | | This is the SMTP port used by your application to delivery e-mails to | users of your application. Like the host we have set this value to | stay compatible with the Postmark e-mail application by default. | */ 'port' => 587, /* |-------------------------------------------------------------------------- | Global "From" Address |-------------------------------------------------------------------------- | | You may wish for all e-mails sent by your application to be sent from | the same address. Here, you may specify a name and address that is | used globally for all e-mails that are sent by your application. | */ 'from' => array('address' => 'admin@klinkon.com', 'name' => 'God'), /* |-------------------------------------------------------------------------- | E-Mail Encryption Protocol |-------------------------------------------------------------------------- | | Here you may specify the encryption protocol that should be used when | the application send e-mail messages. A sensible default using the | transport layer security protocol should provide great security. | */ 'encryption' => 'tls', /* |-------------------------------------------------------------------------- | SMTP Server Username |-------------------------------------------------------------------------- | | If your SMTP server requires a username for authentication, you should | set it here. This will get used to authenticate with your server on | connection. You may also set the "password" value below this one. | */ 'username' => null, /* |-------------------------------------------------------------------------- | SMTP Server Password |-------------------------------------------------------------------------- | | Here you may set the password required by your SMTP server to send out | messages from your application. This will be given to the server on | connection so that the application will be able to send messages. | */ 'password' => null, /* |-------------------------------------------------------------------------- | Sendmail System Path |-------------------------------------------------------------------------- | | When using the "sendmail" driver to send e-mails, we will need to know | the path to where Sendmail lives on this server. A default path has | been provided here, which will work well on most of your systems. | */ 'sendmail' => '/usr/sbin/sendmail -bs', /* |-------------------------------------------------------------------------- | Mail "Pretend" |-------------------------------------------------------------------------- | | When this option is enabled, e-mail will not actually be sent over the | web and will instead be written to your application's logs files so | you may inspect the message. This is great for local development. | */ 'pretend' => false, ); 

И это логика обработки почтовой программы – (это в UserController)

 public function postCreate() { $validator = Validator::make(Input::all(), User::$rules); if ($validator->passes()) { $act_code = str_random(60); $user = new User; $user->user_username = Input::get('user_username'); $user->user_email = Input::get('user_email'); $user->user_password = Hash::make(Input::get('user_password')); $user->user_status = "N"; $user->user_activation_key = $act_code; if($user->save()) { $email_data = array( 'recipient' => $user->user_email, 'subject' => 'Activation Email' ); $view_data = array( 'actkey' => $act_code, ); Mail::send('emails.welcome', $view_data, function($message) use ($email_data) { $message->to( $email_data['recipient'] ) ->subject( $email_data['subject'] ); }); return Redirect::to('login')->with('message', 'Thanks for registering!'); } } else { return Redirect::to('register')->with('message', 'The following errors occurred')->withErrors($validator)->withInput(); } } 

Хорошо, я бы дал Yousef «Up One», но моя репутация недостаточно высока (кажется, сломана). У меня была ТОЧНО такая же проблема с моим провайдером при подключении к их серверу smtp. Единственный способ, которым я мог ПОЛУЧИТЬ электронное письмо с помощью laravel, заключался в том, чтобы установить значение «шифрования» ничто (т.е. так же, как в вышеприведенном сообщении). Каждая другая комбинация изменений порта, смены учетной записи и т. Д. Приводила к исключению laravel. Я попробовал использовать мою учетную запись gmail и учетные данные без везения.

Единственная комбинация настроек, которые в конечном итоге работали, заключалась в использовании

 'host' => 'smtp.your-domain', 'port' => 587, 'encryption' => '', 'username' => 'Your-account@Your-domain', 'password' => 'your-password for Your-account',... 

Расширяясь по ответам выше, поскольку они не работали на меня.

Порт, который вы определяете, должен соотноситься с правильным типом шифрования. Как оказалось, ssl и tls не эквивалентны и коррелируют с разными портами.
Установленный по умолчанию параметр шифрования в laravel устанавливается на tls (порт 587), но если вы используете порт 465, вам нужно изменить его на ssl.

Хорошим примером этого является сервер smtp.gmail.com от Google.

 'host' => 'smtp.gmail.com', 'port' => 465, 'encryption' => 'ssl', 

ИЛИ

 'host' => 'smtp.gmail.com', 'port' => 587, 'encryption' => 'tls', 

Кроме того, порт 587 не требует использования шифрования ( подробнее об этом здесь ). Если вы обнаружите, что параметр 'encryption' => '' работает для вас, он должен поднять красный флаг, так как это может означать, что SMTP-сервер, который вы используете, не шифрует ваши письма.
В этом случае вы должны найти альтернативные способы отправки своих писем.

попробуйте удалить tls-шифрование, установив его в

 'encryption' => '', 

У меня была аналогичная проблема, и это было.

Если вы используете это на локальной машине с помощью Xampp. Отключите все приложения шифрования, которые запущены на задней панели. Я столкнулся с одной проблемой, и она была решена, когда я отключил PGP-шифрование. Программное обеспечение для шифрования не позволяет передавать токен в адрес электронной почты.

Config / mail.php

 <?php return [ /* |-------------------------------------------------------------------------- | Mail Driver |-------------------------------------------------------------------------- | | Laravel supports both SMTP and PHP's "mail" function as drivers for the | sending of e-mail. You may specify which one you're using throughout | your application here. By default, Laravel is setup for SMTP mail. | | Supported: "smtp", "mail", "sendmail", "mailgun", "mandrill", "log" | */ 'driver' => 'sendmail', /* |-------------------------------------------------------------------------- | SMTP Host Address |-------------------------------------------------------------------------- | | Here you may provide the host address of the SMTP server used by your | applications. A default option is provided that is compatible with | the Mailgun mail service which will provide reliable deliveries. | */ 'host' => 'smtp.gmail.com', /* |-------------------------------------------------------------------------- | SMTP Host Port |-------------------------------------------------------------------------- | | This is the SMTP port used by your application to deliver e-mails to | users of the application. Like the host we have set this value to | stay compatible with the Mailgun e-mail application by default. | */ 'port' => 465, /* |-------------------------------------------------------------------------- | Global "From" Address |-------------------------------------------------------------------------- | | You may wish for all e-mails sent by your application to be sent from | the same address. Here, you may specify a name and address that is | used globally for all e-mails that are sent by your application. | */ 'from' => ['address' => 'your mail', 'name' => 'Project'], /* |-------------------------------------------------------------------------- | E-Mail Encryption Protocol |-------------------------------------------------------------------------- | | Here you may specify the encryption protocol that should be used when | the application send e-mail messages. A sensible default using the | transport layer security protocol should provide great security. | */ 'encryption' => '', /* |-------------------------------------------------------------------------- | SMTP Server Username |-------------------------------------------------------------------------- | | If your SMTP server requires a username for authentication, you should | set it here. This will get used to authenticate with your server on | connection. You may also set the "password" value below this one. | */ 'username' => 'your email (gmail)', /* |-------------------------------------------------------------------------- | SMTP Server Password |-------------------------------------------------------------------------- | | Here you may set the password required by your SMTP server to send out | messages from your application. This will be given to the server on | connection so that the application will be able to send messages. | */ 'password' => 'password (email)', /* |-------------------------------------------------------------------------- | Sendmail System Path |-------------------------------------------------------------------------- | | When using the "sendmail" driver to send e-mails, we will need to know | the path to where Sendmail lives on this server. A default path has | been provided here, which will work well on most of your systems. | */ 'sendmail' => '/usr/sbin/sendmail -bs', /* |-------------------------------------------------------------------------- | Mail "Pretend" |-------------------------------------------------------------------------- | | When this option is enabled, e-mail will not actually be sent over the | web and will instead be written to your application's logs files so | you may inspect the message. This is great for local development. | */ 'pretend' => false, ]; 

Функция почты

 use Illuminate\Contracts\Mail\Mailer; $message = [ 'title' => 'Verification code', 'intro' => "Please verify your email address with ".$user->confirmation_code, 'link' => '', 'confirmation_code' => '', 'to_email' => $user->email, 'to_name' => $user_details->first_name.' '.$user_details->last_name, ]; \Mail::send('emails.auth.verify', $message, function($m) use($message) { $m->to($message['to_email'], $message['to_name']) ->subject('Email verification'); });