Php Laravel 6:调用未定义的方法App\\User::createToken()
我正在尝试生成令牌,以通过以下方式对控制器中的用户进行身份验证:Php Laravel 6:调用未定义的方法App\\User::createToken(),php,laravel,eloquent,laravel-passport,laravel-authentication,Php,Laravel,Eloquent,Laravel Passport,Laravel Authentication,我正在尝试生成令牌,以通过以下方式对控制器中的用户进行身份验证: namespace App\Http\Controllers\API; use Illuminate\Foundation\Auth\AuthenticatesUsers; use Illuminate\Http\Request; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\Auth; use App\Models\User; clas
namespace App\Http\Controllers\API;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;
use App\Models\User;
class AuthController extends Controller
{
public function login()
{
if (Auth::attempt(['email' => request('email'), 'password' => request('password')])) {
$user = Auth::user();
$success['token'] = $user->createToken('myApp')->accessToken;
dd($success['token']);
}
}
目前,我正在打印令牌。这是我用户的模型:
<?php
namespace App\Models;
use Illuminate\Notifications\Notifiable;
//use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Support\Facades\Hash;
use Laravel\Passport\HasApiTokens;
class User extends Authenticatable
{
use HasApiTokens, Notifiable;
const USER_FIRST_NAME_FIELD = "first_name";
const USER_LAST_NAME_FIELD = "last_name";
const USER_PREFERRED_NAME_FIELD = "preferred_name";
const USER_EMAIL_FIELD = "email";
const USER_EMAIL_VERIFIED_AT_FIELD = "email_verified_at";
const USER_PASSWORD_FIELD = "password";
const USER_REMEMBER_TOKEN_FIELD = "remember_token";
const USER_RECEIVE_NEWSLETTER_FIELD= "receive_newsletter";
const USER_ACTIVE_FIELD = "active";
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
self::USER_FIRST_NAME_FIELD,
self::USER_LAST_NAME_FIELD,
self::USER_PREFERRED_NAME_FIELD,
self::USER_EMAIL_FIELD,
self::USER_PASSWORD_FIELD,
self::USER_RECEIVE_NEWSLETTER_FIELD,
self::USER_ACTIVE_FIELD,
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
self::USER_PASSWORD_FIELD,
self::USER_REMEMBER_TOKEN_FIELD
];
/**
* Automatically creates password hash when password is submitted
*
* @param string $password
* @return void
*/
public function setPasswordAttribute(string $password) : void
{
$this->attributes['password'] = Hash::make($password);
}
}
这是我的服务:
<?php
namespace App\Services;
use App\Models\User;
use App\Services\BaseServiceInterface;
class UserService implements BaseServiceInterface
{
public function register(array $formValues) : User
{
// 'terms and conditions' should not be saved into the db, hence it's removed
unset($formValues['terms_conditions']);
return User::create($formValues);
}
}
这是我的模型:
<?php
namespace App\Models;
use Illuminate\Notifications\Notifiable;
//use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Support\Facades\Hash;
use Laravel\Passport\HasApiTokens;
class User extends Authenticatable
{
use HasApiTokens, Notifiable;
const USER_FIRST_NAME_FIELD = "first_name";
const USER_LAST_NAME_FIELD = "last_name";
const USER_PREFERRED_NAME_FIELD = "preferred_name";
const USER_EMAIL_FIELD = "email";
const USER_EMAIL_VERIFIED_AT_FIELD = "email_verified_at";
const USER_PASSWORD_FIELD = "password";
const USER_REMEMBER_TOKEN_FIELD = "remember_token";
const USER_RECEIVE_NEWSLETTER_FIELD= "receive_newsletter";
const USER_ACTIVE_FIELD = "active";
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
self::USER_FIRST_NAME_FIELD,
self::USER_LAST_NAME_FIELD,
self::USER_PREFERRED_NAME_FIELD,
self::USER_EMAIL_FIELD,
self::USER_PASSWORD_FIELD,
self::USER_RECEIVE_NEWSLETTER_FIELD,
self::USER_ACTIVE_FIELD,
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
self::USER_PASSWORD_FIELD,
self::USER_REMEMBER_TOKEN_FIELD
];
正如我告诉过你的,当创建一个用户时,令牌是正确生成的
我想说Auth::user并没有直接调用我的模型,但我不确定发生了什么
知道为什么吗?
谢谢所以,这不是正确的方法,但目前正在发挥作用:
<?php
namespace App\Http\Controllers\API;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
use App\Http\Controllers\API\BaseController;
class AuthController extends BaseController
{
public function login()
{
if (Auth::attempt(['email' => request('email'), 'password' => request('password')])) {
$authenticated_user = \Auth::user();
$user = User::find($authenticated_user->id);
dd($user->createToken('myApp')->accessToken);
}
dd('here');
}
}
现在我看到了令牌
我想用正确的方式做,所以如果有人能帮我,我还是会很感激的。
谢谢所以,这不是正确的方法,但目前正在发挥作用:
<?php
namespace App\Http\Controllers\API;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
use App\Http\Controllers\API\BaseController;
class AuthController extends BaseController
{
public function login()
{
if (Auth::attempt(['email' => request('email'), 'password' => request('password')])) {
$authenticated_user = \Auth::user();
$user = User::find($authenticated_user->id);
dd($user->createToken('myApp')->accessToken);
}
dd('here');
}
}
现在我看到了令牌
我想用正确的方式做,所以如果有人能帮我,我还是会很感激的。
谢谢因为你的守卫返回了错误的用户模型App\User,你应该检查你的身份验证配置'config/auth.php'。在提供程序数组中,将使用App\User模型的任何提供程序(通常是用户)调整为App\Models\User
由于您的guard返回了错误的用户模型App\User,您应该检查您的身份验证配置'config/auth.php'。在提供程序数组中,将使用App\User模型的任何提供程序(通常是用户)调整为App\Models\User 通过在构造方法中调用auth.basic中间件,可以让它为您进行身份验证:
public function __construct()
{
$this->middleware('auth.basic');
}
然后为当前经过身份验证的用户生成访问令牌,并将用户信息与访问令牌一起返回:
public function login()
{
$Accesstoken = Auth::user()->createToken('Access Token')->accessToken;
return Response(['User' => Auth::user(), 'Access Token' => $Accesstoken]);
}
现在控制器将如下所示:
<?php
namespace App\Http\Controllers\API;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
use App\Http\Controllers\API\BaseController;
class AuthController extends BaseController
{
/**
* Instantiate a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth.basic');
}
public function login()
{
$Accesstoken = Auth::user()->createToken('Access Token')->accessToken;
return Response(['User' => Auth::user(), 'Access Token' => $Accesstoken]);
}
}
通过在构造方法中调用auth.basic中间件,可以让它为您进行身份验证:
public function __construct()
{
$this->middleware('auth.basic');
}
然后为当前经过身份验证的用户生成访问令牌,并将用户信息与访问令牌一起返回:
public function login()
{
$Accesstoken = Auth::user()->createToken('Access Token')->accessToken;
return Response(['User' => Auth::user(), 'Access Token' => $Accesstoken]);
}
现在控制器将如下所示:
<?php
namespace App\Http\Controllers\API;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
use App\Http\Controllers\API\BaseController;
class AuthController extends BaseController
{
/**
* Instantiate a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth.basic');
}
public function login()
{
$Accesstoken = Auth::user()->createToken('Access Token')->accessToken;
return Response(['User' => Auth::user(), 'Access Token' => $Accesstoken]);
}
}
在我的例子中,我没有使用Trait hasapitoken 这就是为什么拉威尔无法创建代币 只需打开User.php afetr名称空间包括
use Laravel\Passport\HasApiTokens;
然后在课堂上
use HasApiTokens
请注意:我使用的是laravel 7。就我而言,我没有使用特质HasApiTokens 这就是为什么拉威尔无法创建代币 只需打开User.php afetr名称空间包括
use Laravel\Passport\HasApiTokens;
然后在课堂上
use HasApiTokens
请注意:我使用的是laravel 7。您的用户服务/模型是否具有名为createToken的功能?如果没有,那么您需要创建/定义它。没有,他们没有任何名为createToken的方法,我不应该创建它,因为我的模型使用extends Authenticable,并使用名为HasApiTokens的特性。该方法存在于这些类中,如您所见,我的register工作良好,您需要检索用户实例以使用createTokenfunction@JesusErwinSuarez这不是$user=Auth::user;你在干什么?我是说,如果我把它打印出来,我就能看到物体。问题是该实例似乎没有关联createToken,即使我的用户模型有HasApiTokens:您的userservice/模型是否有名为createToken的函数?如果没有,那么您需要创建/定义它。没有,他们没有任何名为createToken的方法,我不应该创建它,因为我的模型使用extends Authenticable,并使用名为HasApiTokens的特性。该方法存在于这些类中,如您所见,我的register工作良好,您需要检索用户实例以使用createTokenfunction@JesusErwinSuarez这不是$user=Auth::user;你在干什么?我是说,如果我把它打印出来,我就能看到物体。问题是,该实例似乎没有关联createToken,即使我的用户模型有HasApiTokens:非常感谢!!!如果我能给你1000分,我会很乐意的。我一整天都在绞尽脑汁思考这个问题,非常感谢!!!如果我能给你1000分,我会很乐意的。我一整天都在绞尽脑汁思考这个问题