Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/276.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php Laravel 6:调用未定义的方法App\\User::createToken()_Php_Laravel_Eloquent_Laravel Passport_Laravel Authentication - Fatal编程技术网

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分,我会很乐意的。我一整天都在绞尽脑汁思考这个问题