本篇文章給大家帶來了關於Laravel的相關知識,其中主要介紹了Laravel Nova是什麼?Laravel中應用中怎麼模擬使用者?感興趣的朋友,下面一起來看一下,希望對大家有幫助。
Laravel Nova 的一個新特性是在控制面板中模擬使用者。這很方便,原因很多。但對於我而言,當收到錯誤報告或問題,並希望看到使用者所看到的內容時,模擬他們可以節省大量時間,因為您可以看到他們所看到的。
如果你也想在你的 Laravel 應用中實現該功能,Laravel Impersonate 包讓這一點變得簡單。
composer require lab404/laravel-impersonate
登入後複製
然後,開啟 config/app.php 並將其新增都 providers 陣列:
'providers' => [
// ...
Lab404\Impersonate\ImpersonateServiceProvider::class,
],
登入後複製
之後,開啟 Models/User 並新增 trait:
use Lab404\Impersonate\Models\Impersonate;
class User extends Authenticatable
{
use Impersonate;
登入後複製
Laravel Impersonate 包包含了一些模擬使用者的方法,不過我發現將路由宏新增到 routes/web.php 檔案中是最為簡便的方法:
Route::impersonate();
登入後複製
這給你一些命名路由:
// Where $id is the ID of the user you want to impersonate
route('impersonate', $id)
// Or in case of multi guards, you should also add `guardName` (defaults to `web`)
route('impersonate', ['id' => $id, 'guardName' => 'admin'])
// Generate an URL to leave the current impersonation
route('impersonate.leave')
登入後複製
Laravel Impersonate 設定就緒後,你可以使用 其中模板 helpers:
@canImpersonate($guard = null)
<a href="{{ route('impersonate', $user->id) }}">Impersonate this user</a>
@endCanImpersonate
登入後複製
然後反轉:
@impersonating($guard = null)
<a href="{{ route('impersonate.leave') }}">Leave impersonation</a>
@endImpersonating
登入後複製
另一個你可能會考慮的是,限制誰可以模擬其他使用者,以及那些使用者可以被模擬。在 Models/User 中,你可以新增以下方法:
/**
* By default, all users can impersonate anyone
* this example limits it so only admins can
* impersonate other users
*/
public function canImpersonate(): bool
{
return $this->is_admin();
}
/**
* By default, all users can be impersonated,
* this limits it to only certain users.
*/
public function canBeImpersonated(): bool
{
return ! $this->is_admin();
}
登入後複製
推薦學習:《》
以上就是詳解Laravel應用中模擬使用者的方法(附程式碼步驟)的詳細內容,更多請關注TW511.COM其它相關文章!