По умолчанию почта Laravel не работает
Я пытаюсь отправить электронное письмо активации при регистрации. У меня есть простой сайт laravel с регистрацией и аутентификацией. При регистрации отсутствуют ошибки, и данные хранятся правильно, однако письмо никогда не отправляется. Пробовал несколько разных примеров, но у меня такая же проблема.
Это мой конфигурационный файл mail.php -
<?php
return array(
/*
|--------------------------------------------------------------------------
| Mail Driver
|--------------------------------------------------------------------------
|
| Laravel supports both SMTP and PHP "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' => '[email protected]', '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 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();
}
}
Ответы
Ответ 1
Хорошо, я бы дал Yousef '' Up One ''
, но моя репутация недостаточно высока (кажется, сломан). У меня была ТОЧНО такая же проблема с моим провайдером при подключении к их серверу smtp. Единственный способ, которым я мог ПОЛУЧИТЬ электронное письмо с помощью laravel, заключался в том, чтобы установить значение "шифрования" ничто (т.е. так же, как в вышеприведенном сообщении). Каждая другая комбинация изменений порта, смены учетной записи и т.д. Приводила к исключению laravel. Я пробовал использовать мою учетную запись gmail и учетные данные без везения.
Единственная комбинация настроек, которая в конечном итоге работала, заключалась в использовании
'host' => 'smtp.your-domain',
'port' => 587,
'encryption' => '',
'username' => '[email protected]',
'password' => 'your-password for Your-account',...
Ответ 2
Развернувшись на ответы выше, поскольку они не работали для меня.
Порт, который вы определяете, должен соотноситься с правильным типом шифрования. Как оказалось, ssl и tls не эквивалентны и не коррелируют с разными портами.
Установленный по умолчанию параметр шифрования в laravel установлен на tls (порт 587), но если вы используете порт 465, вам нужно изменить его на ssl.
Google smtp.gmail.com - хороший пример:
'host' => 'smtp.gmail.com',
'port' => 465,
'encryption' => 'ssl',
ИЛИ
'host' => 'smtp.gmail.com',
'port' => 587,
'encryption' => 'tls',
Кроме того, порт 587 не предусматривает использование шифрования (подробнее об этом здесь). Если вы обнаружите, что настройка 'encryption' => ''
работает для вас, она должна поднять красный флаг, поскольку это может означать, что используемый вами SMTP-сервер не шифрует ваши электронные письма.
В этом случае вы должны найти альтернативные способы отправки своих писем.
Ответ 3
попробуйте удалить tls-шифрование, установив его в
'encryption' => '',
У меня была аналогичная проблема, и это было tls.
Ответ 4
Если вы используете это на локальной машине с помощью Xampp. Отключите все приложения шифрования, которые запущены на задней панели. Я столкнулся с одной проблемой, и она была решена, когда я отключил PGP-шифрование. Программное обеспечение для шифрования не позволяет передавать токен в адрес электронной почты.
Ответ 5
Config/mail.php
<?php
return [
/*
|--------------------------------------------------------------------------
| Mail Driver
|--------------------------------------------------------------------------
|
| Laravel supports both SMTP and PHP "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 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');
});