我已经使用laravel passport创建了一个身份验证控制器,但结果并不是它通常的样子。变量$token = $user->createToken('TestApp')->accessToken;
不会在oauth_access_tokens
表中生成标记,而是在personal_access_token
表中创建标记
我的注册控制器是
public function register(Request $request)
{
$validator = Validator::make($request->all(), [
'name' => 'required',
'username' => 'required|unique:users,username',
'email' => 'required|email|unique:users,email',
'password' => 'required|confirmed',
'phone' => 'required',
]);
if ($validator->fails()) {
return response()->json(['error'=>$validator->errors()], 401);
}
$input = $request->all();
$input['password'] = bcrypt($input['password']);
$user = User::create($input);
$verifyUser = UserVerfication::create([
'user_id' => $user->id,
'token' => sha1(time())
]);
\Mail::to($user->email)->send(new VerifyMail($user));
$token = $user->createToken('TestApp')->accessToken;
return response()->json([
'success' => true,
'message' => 'Registration Success',
'data' => array('APItoken' => $token, 'user' => $user)
], 200);
}
结果是:
"APItoken": {
"name": "LinwokApp",
"abilities": [
"*"
],
"tokenable_id": 13,
"tokenable_type": "App\\Models\\User",
"updated_at": "2021-09-22T08:55:12.000000Z",
"created_at": "2021-09-22T08:55:12.000000Z",
"id": 11},
4条答案
按热度按时间7gs2gvoe1#
我不知道这个问题是否仍然有效,但我遇到了同样的问题,并找到了解决方案。
查看您拥有HasApiTokens的名称空间。
我用的是:
使用Laravel\Sanctum\HasApiTokens;
而不是
使用Laravel\Passport\HasApiTokens;
这就是问题的根源
frebpwbc2#
一切都是正确的。在你的用户模型中,你应该调用'use Laravel\Passport\HasApiTokens'而不是'use Laravel\Sanctum\HasApiTokens'。默认情况下,Laravel配置Sanctum。
f8rj6qna3#
当你使用Laravel Passport时,你必须将“use Laravel\Sanctum\HasApiTokens;使用Laravel\Passport\HasApiTokens;“在User.php中
flvlnr444#
这意味着您正在使用Sanctum而不是Passport
变化
到