0% found this document useful (0 votes)
61 views

Laravel 7 Send Email

This document provides instructions for configuring email sending in a newly installed Laravel 7 application. The key steps are: 1. Add an interface to the User model for email verification. 2. Configure routes for email verification. 3. Replace the default Laravel mail configuration file with the one provided, which is pre-configured for Gmail SMTP sending. 4. Optionally customize the "from" name in the mail configuration.

Uploaded by

Gabriel Maraima
Copyright
© © All Rights Reserved
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
61 views

Laravel 7 Send Email

This document provides instructions for configuring email sending in a newly installed Laravel 7 application. The key steps are: 1. Add an interface to the User model for email verification. 2. Configure routes for email verification. 3. Replace the default Laravel mail configuration file with the one provided, which is pre-configured for Gmail SMTP sending. 4. Optionally customize the "from" name in the mail configuration.

Uploaded by

Gabriel Maraima
Copyright
© © All Rights Reserved
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 4

Configuracion de Laravel para enviar correo electronico en una app recien instalada.

Probada en Laravel 7

1. Agregar la linea siguiente al modelo User:

class User extends Authenticatable implements MustVerifyEmail

2. El archivo web.php debe quedar de la siguiente forma:

Route::get('/', function () {
return view('auth/login');
});

Auth::routes(['verify' => true]);


Auth::routes();

Route::get('email/verify', 'Auth\VerificationController@show')-
>name('verification.notice');
Route::get('email/verify/{id}/{hash}', 'Auth\VerificationController@verify')-
>name('verification.verify');
Route::get('email/resend', 'Auth\VerificationController@resend')-
>name('verification.resend');
Route::get('/home', 'HomeController@index')->name('home')->middleware('verified');

3. Se debe usar el archivo \config\mail.php adjunto en este correo y no el que trae laravel 7 por defecto. El
codigo es el siguiente:

<?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", "sendmail", "mailgun", "ses",
| "postmark", "log", "array"
|
*/

'driver' => env('MAIL_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 Mailgun mail service which will provide reliable deliveries.
|
*/

'host' => env('MAIL_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' => env('MAIL_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' => env('MAIL_FROM_ADDRESS', '[email protected]'),
'name' => env('MAIL_FROM_NAME', 'NAME),
],

/*
|--------------------------------------------------------------------------
| 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' => env('MAIL_ENCRYPTION', 'ssl'),

/*
|--------------------------------------------------------------------------
| 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' => env('MAIL_USERNAME'),

'password' => env('MAIL_PASSWORD'),

/*
|--------------------------------------------------------------------------
| 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',

/*
|--------------------------------------------------------------------------
| Markdown Mail Settings
|--------------------------------------------------------------------------
|
| If you are using Markdown based email rendering, you may configure your
| theme and component paths here, allowing you to customize the design
| of the emails. Or, you may simply stick with the Laravel defaults!
|
*/

'markdown' => [
'theme' => 'default',

'paths' => [
resource_path('views/vendor/mail'),
],
],

/*
|--------------------------------------------------------------------------
| Log Channel
|--------------------------------------------------------------------------
|
| If you are using the "log" driver, you may specify the logging channel
| if you prefer to keep mail messages separate from other log entries
| for simpler reading. Otherwise, the default channel will be used.
|
*/

'log_channel' => env('MAIL_LOG_CHANNEL'),

'stream' => [
'ssl' => [
'allow_self_signed' => true,
'verify_peer' => false,
'verify_peer_name' => false,
],
],

];

4. Se recomienda personalizar la linea:

'name' => env('MAIL_FROM_NAME', 'CARD'),

You might also like