Сброс пароля не работает с настройкой mailgun
Я настроил laravel 5.1 согласно почтовым документам. Отправка почты работает нормально.
Следующим шагом было добавить пароль для сброса в соответствии с документами для сброса паролей. Здесь я изо всех сил пытаюсь отправить ссылку на форму сброса пароля.
Похоже, что функция отправки почты для сброса не сработала. Я также проверил с config/mail.php
конфигурация pretend = true;
, В лог-файле не было записи о том, что электронное письмо было отправлено.
Каким-то образом его также сложно отладить, так как я не смог найти функцию, при которой сбрасывается электронная почта сброса.
- Как отправить пароль для сброса с помощью mailgun?
- Где находится функция locate для отправки пароля сброса или где я могу перезаписать его, чтобы проверить?
Это мои конфигурации:
.env
# ...
MAIL_DRIVER=mailgun
MAIL_HOST=smtp.mail.org
MAIL_PORT=587
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAILGUN_DOMAIN=mg.foo.com
MAILGUN_SECRET=key-foobar.etc
# ....
конфиг /service.php
//...
'mailgun' => [
'domain' => env('MAILGUN_DOMAIN'),
'secret' => env('MAILGUN_SECRET'),
],
//...
конфиг /mail.php
// ...
'driver' => env('MAIL_DRIVER', 'smtp'),
'host' => env('MAIL_HOST', 'smtp.mailgun.org'),
'port' => env('MAIL_PORT', 587),
'from' => ['address' => 'foo@test.com', 'name' => 'foo'],
'encryption' => env('MAIL_ENCRYPTION', 'tls'),
'username' => env('MAIL_USERNAME'),
'password' => env('MAIL_PASSWORD'),
'pretend' => false,
// ...
приложение /Http/routes.php
// ...
Route::group([
'prefix' => LaravelLocalization::setLocale(),
'middleware' => [ 'localeSessionRedirect', 'localizationRedirect' ]
], function() {
//Route::controllers([ 'password' => 'Auth\PasswordController', ]);
// works only if the user is logged out!!!1
// Password reset link request routes...
Route::get('password/email', 'Auth\PasswordController@getEmail');
Route::post('password/email', 'Auth\PasswordController@postEmail');
// Password reset routes...
Route::get('password/reset/{token}', 'Auth\PasswordController@getReset');
Route::post('password/reset', 'Auth\PasswordController@postReset');
});
//...
ресурсы / виды / авториз /password.blade.php
@extends('layout')
@section('content')
<div class="container">
<form method="POST" action="/password/email">
{!! csrf_field() !!}
@if (count($errors) > 0)
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
@endif
<div class="row">
<div class="col-md-6">
{!! Form::label('email', trans( 'mes.email' )) !!}
<input type="email" name="email" value="{{ old('email') }}" class="form-control">
</div>
<div class="col-md-8">
<button type="submit" class="btn">
Send Password Reset Link
</button>
</div>
<div>
</form>
</div>
@endsection
1 ответ
Неправильные маршруты были проблемой. Пример из документации сделал жесткий код action
значение в form
элемент.
Это не отражало мою конфигурацию маршрутов. При следующих изменениях работает электронная почта для сброса пароля:
Приложение /HTTP / маршруты
// change route to a named route
// Route::post('password/email', 'Auth\PasswordController@postEmail');
Route::post('password/email', ['as' => 'password.email', 'uses' => 'Auth\PasswordController@postEmail']);
ресурсы / виды / авториз /password.blade.php
<!-- Use the named route in the form builder and remove csrf_field -->
{!! Form::open(['route' => 'password.email']) !!}