Я читал документацию о новой функции laravel проверки электронной почты. Где я могу найти шаблон электронной почты, который отправляется пользователю? Здесь не отображается: https://laravel.com/docs/5.7/verification#after-verifying-emails






Laravel использует этот метод класса уведомлений Подтвердить электронную почту для отправки электронной почты:
public function toMail($notifiable)
{
if (static::$toMailCallback) {
return call_user_func(static::$toMailCallback, $notifiable);
}
return (new MailMessage)
->subject(Lang::getFromJson('Verify Email Address'))
->line(Lang::getFromJson('Please click the button below to verify your email address.'))
->action(
Lang::getFromJson('Verify Email Address'),
$this->verificationUrl($notifiable)
)
->line(Lang::getFromJson('If you did not create an account, no further action is required.'));
}
Если вы хотите использовать свой собственный шаблон электронной почты, вы можете расширить базовый класс уведомлений.
app/Notifications/ файл VerifyEmail.php<?php
namespace App\Notifications;
use Illuminate\Bus\Queueable;
use Illuminate\Notifications\Notification;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Notifications\Messages\MailMessage;
use Illuminate\Support\Carbon;
use Illuminate\Support\Facades\URL;
use Illuminate\Support\Facades\Lang;
use Illuminate\Auth\Notifications\VerifyEmail as VerifyEmailBase;
class VerifyEmail extends VerifyEmailBase
{
// use Queueable;
// change as you want
public function toMail($notifiable)
{
if (static::$toMailCallback) {
return call_user_func(static::$toMailCallback, $notifiable);
}
return (new MailMessage)
->subject(Lang::getFromJson('Verify Email Address'))
->line(Lang::getFromJson('Please click the button below to verify your email address.'))
->action(
Lang::getFromJson('Verify Email Address'),
$this->verificationUrl($notifiable)
)
->line(Lang::getFromJson('If you did not create an account, no further action is required.'));
}
}
use App\Notifications\VerifyEmail;
а также
/**
* Send the email verification notification.
*
* @return void
*/
public function sendEmailVerificationNotification()
{
$this->notify(new VerifyEmail); // my notification
}
Также, если вам нужен шаблон лезвия:
laravel will generate all of the necessary email verification views when the
make:authcommand is executed. This view is placed inresources/views/auth/verify.blade.php. You are free to customize this view as needed for your application.
@laze Спасибо, написал как переопределить базовый емайл.
Да, теперь все в порядке, это настоящее решение! ;)
На самом деле они не используют никаких лезвий или файлов шаблонов. Они создают уведомления и пишут для этого код в уведомлениях.
Кроме того, если вы хотите перевести стандартную почту Подтвердить электронную почту (или другую, где используется Lang :: fromJson (...)), вам нужно создать новый файл json в resources / lang / и назвать его, например, ru.json. Он может содержать текст (resources / lang / ru.json) ниже и должен быть действительным.
{
"Verify Email Address" : "Подтверждение email адреса"
}
Если уведомление поддерживает отправку по электронной почте, вы должны определить метод toMail в классе уведомлений. Этот метод получит объект $ notifiable и должен вернуть экземпляр Illuminate \ Notifications \ Messages \ MailMessage. Почтовые сообщения могут содержать строки текста, а также «призыв к действию».
/**
* Get the mail representation of the notification.
*
* @param mixed $notifiable
* @return \Illuminate\Notifications\Messages\MailMessage
*/
public function toMail($notifiable)
{
$url = url('/invoice/'.$this->invoice->id);
return (new MailMessage)
->greeting('Hello!')
->line('One of your invoices has been paid!')
->action('View Invoice', $url)
->line('Thank you for using our application!');
}
Вы можете использовать конструктор электронной почты laravel, как описано здесь: https://laravel.com/docs/5.8/notifications#mail-notifications. Laravel позаботится о просмотре электронной почты.
Хотя эта ссылка может дать ответ на вопрос, лучше включить сюда основные части ответа и предоставить ссылку для справки. Ответы, содержащие только ссылки, могут стать недействительными, если ссылка на страницу изменится. - Из обзора
@Zoe Я считаю маловероятным, что Laravel удалит старую документацию в ближайшие годы, поскольку у них очень хороший послужной список по хранению старой документации в Интернете. Я обновил свой пост.
@scre_www источник ссылки не имеет значения - правила универсальны. Я снял свой флаг
Ответ уже в комментарии. Отправлено методом toMail().
vendor\laravel\framework\src\Illuminate\Auth\Notifications\VerifyEmail::toMail();
За структуру и внешний вид шаблона; также взгляните на эти места, и вы также можете опубликовать, чтобы изменить шаблон:
\vendor\laravel\framework\src\Illuminate\Notifications\resources\views\email.blade.php
\vendor\laravel\framework\src\Illuminate\Mail\resources\views\
Чтобы опубликовать эти места:
php artisan vendor:publish --tag=laravel-notifications
php artisan vendor:publish --tag=laravel-mail
После выполнения этой команды шаблоны почтовых уведомлений будут расположены в каталоге resources/views/vendor.
Цвета и стиль контролируются файлом CSS в resources/views/vendor/mail/html/themes/default.css.
Пожалуйста, email.blade.php - это компонент, какой шаблон использует этот компонент и как я могу его настроить? Благодарность
Look I do that very easy do the following steps :
В файле маршрута
Auth::routes(['verify' => true]);
In AppServiceProvider.php File
namespace App\Providers;
use App\Mail\EmailVerification;
use Illuminate\Support\ServiceProvider;
use View;
use URL;
use Carbon\Carbon;
use Config;
use Illuminate\Auth\Notifications\VerifyEmail;
use Illuminate\Notifications\Messages\MailMessage;
class AppServiceProvider extends ServiceProvider
{
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
// Override the email notification for verifying email
VerifyEmail::toMailUsing(function ($notifiable){
$verifyUrl = URL::temporarySignedRoute('verification.verify',
\Illuminate\Support\Carbon::now()->addMinutes(\Illuminate\Support\Facades
\Config::get('auth.verification.expire', 60)),
[
'id' => $notifiable->getKey(),
'hash' => sha1($notifiable->getEmailForVerification()),
]
);
return new EmailVerification($verifyUrl, $notifiable);
});
}
}
Now Create EmailVerification With Markdown
php artisan make:mail EmailVerification --markdown=emails.verify-email
Отредактируйте EmailVerrification по своему усмотрению и файл лезвия.
class EmailVerification extends Mailable
{
use Queueable, SerializesModels;
public $verifyUrl;
protected $user;
/**
* Create a new message instance.
*
* @return void
*/
public function __construct($url,$user)
{
$this->verifyUrl = $url;
$this->user = $user;
}
/**
* Build the message.
*
* @return $this
*/
public function build()
{
$address = '[email protected]';
$name = 'Name';
$subject = 'verify Email';
return $this->to($this->user)->subject($subject)->from($address, $name)->
markdown('emails.verify',['url' => $this->verifyUrl,'user' => $this->user]);
}
}
in the blade file change the design as you want and use verifyUrl to display the verification link and $user to display user information
спасибо, удачного кодирования :)
поставщик \ laravel \ framework \ src \ Illuminate \ Mail \ resources \ views \ html u найдет шаблон электронной почты по умолчанию laravel в этом месте файла.
Это шаблон страницы подтверждения, а не электронное письмо. Электронное письмо было отправлено методом
vendor\laravel\framework\src\Illuminate\Auth\Notifications\VerifyEmail::toMail().