Laravel:Auth::user()->идентификатор, пытающийся получить свойство не-объекта
Я получаю следующую ошибку "пытаюсь получить свойство не-объекта", когда я отправляю форму для добавления пользователя, ошибка, по-видимому, находится в первой строке: Auth::user()->идентификатор следующего:
$id = Auth::user()->id;
$currentuser = User::find($id);
$usergroup = $currentuser->user_group;
$group = Sentry::getGroupProvider()->findById($usergroup);
$generatedPassword = $this->_generatePassword(8,8);
$user = Sentry::register(array('email' => $input['email'], 'password' => $generatedPassword, 'user_group' => $usergroup));
$user->addGroup($group);
Есть идеи? Я искал некоторое время, и все, что я вижу, говорит о том, что это должно работать нормально. Мой пользователь вошел в систему с помощью пакета аутентификации Sentry 2.
9 answers
Если вы используете Sentry
, проверьте вошедшего в систему пользователя с помощью Sentry::getUser()->id
. Ошибка, которую вы получаете, заключается в том, что Auth::user()
возвращает NULL и пытается получить идентификатор из NULL, следовательно, ошибка trying to get a property from a non-object
.
Выполните проверку подлинности::проверьте(), прежде чем убедиться, что вы правильно вошли в систему:
if (Auth::check())
{
// The user is logged in...
}
Теперь с laravel 4.2 легко получить идентификатор пользователя:
$userId = Auth::id();
Вот и все.
Но для получения данных пользователя, отличных от идентификатора, вы используете:
$email = Auth::user()->email;
Для получения более подробной информации проверьте часть документации, посвященную безопасности
Идентификатор protected
, просто добавьте общедоступный метод в свой /models/User.php
public function getId()
{
return $this->id;
}
Так что вы можете назвать это
$id = Auth::user()->getId();
Всегда помните, чтобы проверить, зарегистрирован ли пользователь...
if (Auth::check())
{
$id = Auth::user()->getId();
}
Проверьте route
на наличие функции, в которой вы используете Auth::user()
, Для получения данных Auth::user() функция должна находиться внутри web
промежуточного программного обеспечения Route::group(['middleware' => 'web'], function () {});
.
Использовать Подсветку\Поддержку\Фасадов\Авторизация;
В классе:
protected $user;
Этот код работает для меня
В конструкции:
$this->user = User::find(Auth::user()->id);
In function:
$this->user->id;
$this->user->email;
И т.д.
Ваш вопрос и пример кода немного расплывчаты, и я считаю, что другие разработчики сосредотачиваются не на том. Я создаю приложение в Laravel, использовал онлайн-учебники для создания нового пользователя и аутентификации и, похоже, заметил, что при создании нового пользователя в Laravel не создается объект аутентификации, который вы используете для получения (нового) идентификатора пользователя, вошедшего в систему, в остальной части приложения. Это проблема, и я верю в то, о чем вы, возможно, спрашиваете. Я сделал такой вид о неуклюжем взломе в UserController::store:
$user->save();
Session::flash('message','Successfully created user!');
//KLUDGE!! rest of site depends on user id in auth object - need to force/create it here
Auth::attempt(array('email' => Input::get('email'), 'password' => Input::get('password')), true);
Redirect::to('users/' . Auth::user()->id);
Не нужно было создавать и аутентифицировать, но я не знал, что еще можно сделать.
Если кто-то ищет laravel 5>
Auth::id()
Укажите идентификатор авторизованного пользователя
В Laravel 5.6 я использую
use Auth;
$user_id = Auth::user()->id;
В качестве другого предложения
Auth::id()
Похоже, применимо к более старым версиям Laravel 5.x и не работало для меня.