[英]Laravel sanctum getting wrong user
我已经用我的应用程序记录了用户,当我发送用户令牌以从服务器获取数据时,它返回了错误用户的数据。
调试
login
到stored token
都显示正确的令牌等。API login function
并获得了正确的用户并将令牌分配给它。代码
public function index(Request $request)
{
$user = $request->user();
Log::info($user); // wrong user will be printed in log file
$will = Will::where('user_id', $user->id)->with(['documents', 'videos', 'user'])->first();
return response()->json([
'data' => new WillResource($will),
'message' => 'Data is ready.'
], 200);
}
路线
Route::group(['middleware' => 'auth:sanctum', 'prefix' => 'userdata'], function() {
Route::get('mywill', 'Api\WillController@index');
});
知道为什么 sanctum 返回错误的用户数据吗?
这是我通过 postman 尝试的时候
接收admin@admin.com
的用户信息
$token = $user->createToken($request->deviceName)->plainTextToken;
$user['token'] = $token;
使用这样的方法在用户登录/注册时创建一个关联的令牌,然后在 $user['token'] 中添加新密钥,然后返回响应槽资源
解决了
问题是我将uuid
用于我的 users 表,而personal_access_tokens
表可以使用id
进行变形,所以我将其更改为uuidMorphs
现在它正在工作
Schema::create('personal_access_tokens', function (Blueprint $table) {
$table->bigIncrements('id');
$table->uuidMorphs('tokenable'); // <--- here
$table->string('name');
$table->string('token', 64)->unique();
$table->text('abilities')->nullable();
$table->timestamp('last_used_at')->nullable();
$table->timestamps();
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.