Wie kann ich die Fehlermeldungen (z. B. "These credentials do not match our records."
) anpassen, die bei fehlgeschlagener Anmeldung/Registrierung angezeigt werden, ohne die Basisdateien zu berühren? Ich bin auf der Suche nach einer Lösung und hoffentlich ein eleganten, zumindest nicht zu berühren AuthenticatesAndRegistersUsers
noch ThrottlesLogins
:)Laravel 5.2 - Auth: benutzerdefinierte Fehlermeldungen anzeigen
Ich benutze die AuthController
und durch Laravel hierfür vorgesehenen Formulare nach der Ausführung:
php Handwerker machen: auth
Controller:
(es nur einen Konstruktor und zwei Methoden hat, fällt der Rest auf der foun dierung sind die Methoden :)
protected function validator(array $data)
{
return Validator::make($data, [
'name' => 'required|max:255',
'email' => 'required|email|max:255|unique:users',
'password' => 'required|confirmed|min:6',
]);
}
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => bcrypt($data['password']),
]);
}
Form:
<form class="form-horizontal" role="form" method="POST" action="{{ url('/login') }}">
{!! csrf_field() !!}
<div class="form-group{{ $errors->has('email') ? ' has-error' : '' }}">
<label class="col-md-4 control-label">E-Mail</label>
<div class="col-md-6">
<input type="email" class="form-control" name="email" value="{{ old('email') }}" required>
@if ($errors->has('email'))
<span class="help-block">
<strong>{{ $errors->first('email') }}</strong>
</span>
@endif
</div>
</div>
<div class="form-group{{ $errors->has('password') ? ' has-error' : '' }}">
<label class="col-md-4 control-label">Password</label>
<div class="col-md-6">
<input type="password" class="form-control" name="password" required>
@if ($errors->has('password'))
<span class="help-block">
<strong>{{ $errors->first('password') }}</strong>
</span>
@endif
</div>
</div>
<div class="form-group">
<div class="col-md-6 col-md-offset-4">
<div class="checkbox">
<label>
<input type="checkbox" name="remember"> Remember Me
</label>
</div>
</div>
</div>
<div class="form-group">
<div class="col-md-6 col-md-offset-4">
<button type="submit" class="btn btn-primary">
<i class="fa fa-btn fa-sign-in"></i>Login
</button>
<a class="btn btn-link" href="{{ url('/password/reset') }}">Forgot Your Password?</a>
</div>
</div>
Thank you!
Danke für die Antwort @lagbox! Wie wäre es mit jeder anderen Fehlermeldung, "Das Namensfeld ist erforderlich." oder "Die Passwortbestätigung stimmt nicht überein." auf dem Benutzerregistrierungsformular? –
Dies sind die Validierungsnachrichten. Sie können den AuthController so anpassen, dass er Ihr eigenes Nachrichtenarray an den Validierungsaufruf weiterleitet oder diese global in der lang-Datei aktualisiert, von der sie stammen. – lagbox
Akzeptiert und Upvoted, danke, mein Herr! –