O flash de sessão do Laravel 5.2 não funciona mesmo com o middleware da web
Estou tentando implementar mensagens em flash usando sessões, mas não consigo fazer isso.
No meu controlador eu tenho:
public function store(Request $request) {
session()->flash('donald', 'duck');
session()->put('mickey', 'mouse');
return redirect()->action('CustomerController@index')->with('bugs', 'bunny');
}
Mas quando verifico as variáveis da sessão na visualização, só consigo ver os valores desession()->put('mickey', 'mouse')
.
Sessão:
{"_token":"F6DoffOFb17B36eEJQruxvPe0ra1CbyJiaooDn3F","_previous":{"url":"http:\/\/localhost\/customers\/create"},"flash":{"old":[],"new":[]},"mickey":"mouse"}
Muitas pessoas encontraram esse problema por não ter as rotas relevantes dentro do middleware da web. Eu fiz isso também, mas ainda não funcionou.
Em routes.php:
Route::group(['middleware' => ['web']], function () {
Route::get('/', function () {
return view('welcome');
});
Route::get('/customers', 'CustomerController@index');
Route::get('/customers/create', 'CustomerController@create');
Route::post('/customers', 'CustomerController@store');
});
No Kernel.php:
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
],
'api' => [
'throttle:60,1',
],
];
Alguém pode me dizer o que eu poderia estar fazendo de errado aqui? Obrigado!