SQLSTATE [23000]:违反完整性约束:1048列“ tokenable_id”不能为空

时间:2020-07-05 12:06:03

标签: postman laravel-7 laravel-sanctum laravel-api

我想在2个模型中使用laravel圣殿

这是用户模型的代码

<?php namespace App; 
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use Laravel\Sanctum\HasApiTokens;
class User extends Authenticatable
{
use HasApiTokens,Notifiable;

/**
 * The attributes that are mass assignable.
 *
 * @var array
 */
protected $fillable = [
   'id', 'name', 'family','gender','birhday','national_code','email','mobile','profie_pic','province_code','city_code','address','username','role','status','password',
];

/**
 * The attributes that should be hidden for arrays.
 *
 * @var array
 */
protected $hidden = [
    'password', 'remember_token','role',
];

/**
 * The attributes that should be cast to native types.
 *
 * @var array
 */
protected $casts = [
    'email_verified_at' => 'datetime',
];

}

和用于登录功能的用户控制器为:

public function login(Request $request) { 
$user= User::where('email', $request->email)->first();
if (!$user || !Hash::check($request->password, $user->password)) {
    return response([
        'message' => ['These credentials do not match our records.']
    ], 404);
}

$token = $user->createToken('my-app-token')->plainTextToken;
$response = [
    'user' => $user,
    'token' => $token
];
 return response($response, 201);

}

和令牌是真的,并且所有带有中间件的路由都可以使用('auth:sanctum'),但是我想使用模型nurces并编写此代码 首先:模型护理:

class Nurces extends model
{
use HasApiTokens,Notifiable;

protected $fillable = [
    'name', 'family','gender','birhday','national_code','email','mobile','profie_pic','province_code','city_code','address','username','status','password',
 ];

 /**
  * The attributes that should be hidden for arrays.
  *
  * @var array
  */
 protected $hidden = [
     'password','remember_token',
 ];
 protected $primaryKey = 'nurces_id';

}

在nurcescontroller中的功能登录为:

public function login(Request $request) { 
$nurces= Nurces::where('email', $request->email)->first();

if (!$nurces || !Hash::check($request->password, $nurces->password)) {
    return response([
        'message' => ['These credentials do not match our records.']
    ], 404);
}

 $token = $nurces->createToken('my-nurces-token-')->plainTextToken;

$response = [
    'nurces' => $nurces,
    'token' => $token
];

 return response($response, 201);

} 使用邮递员并使用此地址登录时-此erorr:

"message": "SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'tokenable_id' cannot be null (SQL: insert into `personal_access_tokens` (`name`, `token`, `abilities`, `tokenable_id`, `tokenable_type`, `updated_at`, `created_at`) values (my-nurces-token-, fa55707e2bd9e1b71f8e5ebc0623f9ce1cc8e49f5b6e1ff804dda262e93811f4, [\"*\"], ?, App\\Nurces, 2020-07-05 11:18:58, 2020-07-05 11:18:58))",

1 个答案:

答案 0 :(得分:0)

我认为, App \ Nurces 模型的主键之间不匹配。

根据文档和错误, personal_access_tokens 表的两列值如下:

  • tokenable_type-型号名称例如 App \ Model \ User
  • tokenable_id-模型的主键

在您的情况下,试图插入为 NULL tokenable_id 值,这就是为什么会出错。

请检查并确认 App \ Nurces 模型的主键列名称。在 Nurces 模型类中添加以下属性。

受保护的$ primaryKey ='主键列名称';

https://laravel.com/docs/7.x/eloquent

相关问题