首页 > 解决方案 > 带有 Vue 3 API 调用的 Laravel sanctum

问题描述

我正在使用 Laravel 后端和 Vue3 构建一个应用程序。这两个应用程序位于不同的域中。我正在从 Vue 进行 axios API 调用。在 Laravel 上,我安装了 Sanctum 来处理我的授权、登录等......我尝试了很多东西,从存储令牌到 localStorage(不是一个好习惯,因为它不安全)。所以我读了更多,发现我必须发送 -withCredentials: true它会用 cookie 处理一切,开箱即用。这没用。然后我读到如果它们在不同的域上,它就不起作用。我不知道如何处理这个了。

这一切都是真的吗?sanctum 有路要走吗?如果没有,安全身份验证的最佳方式是什么?它会在相同的域上工作吗?有没有办法在不同的域上工作?

有谁知道如何处理这个问题?

谢谢!!!

标签: laravelvue.jsaxioslaravel-sanctum

解决方案


拥有 2 个域不会改变任何事情。逻辑很简单。基本上你有一个令牌(密钥),你将与这个密钥进行通信。满足条件时,您将向客户端发送令牌。之后,客户说“如果这是您的令牌,请提供我的凭据。”

只需使用圣所令牌:

  $user->createToken($request->name)->plainTextToken;

如果满足条件,则返回 Bearer 令牌:

Authorization: Bearer <token>

并使用 sanctum 中间件保护您的路线:

Route::middleware('auth:sanctum')->get('/user', function (Request $request)

最后,如果密钥正确:

return response($user, 200);

推荐阅读