Сброс пароля не работает с настройкой mailgun

Я настроил laravel 5.1 согласно почтовым документам. Отправка почты работает нормально.

Следующим шагом было добавить пароль для сброса в соответствии с документами для сброса паролей. Здесь я изо всех сил пытаюсь отправить ссылку на форму сброса пароля.

Похоже, что функция отправки почты для сброса не сработала. Я также проверил с config/mail.php конфигурация pretend = true;, В лог-файле не было записи о том, что электронное письмо было отправлено.

Каким-то образом его также сложно отладить, так как я не смог найти функцию, при которой сбрасывается электронная почта сброса.

  1. Как отправить пароль для сброса с помощью mailgun?
  2. Где находится функция 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']) !!}
Другие вопросы по тегам