Amalan Terbaik untuk Fungsi Kebenaran Laravel: Cara Melaksanakan Caching Kebenaran dan Pengoptimuman Prestasi
Pengenalan: #🎜🎜 is ma Web adalah sebahagian daripada aplikasi. Ciri kebenaran rangka kerja Laravel sangat berkuasa dan mudah digunakan, tetapi mungkin terdapat prestasi yang terjejas apabila berurusan dengan sejumlah besar kebenaran. Artikel ini akan memperkenalkan beberapa amalan terbaik untuk membantu anda mengoptimumkan fungsi kebenaran dalam aplikasi Laravel anda dan melaksanakan caching kebenaran untuk meningkatkan prestasi.
Bagi kebanyakan aplikasi, semakan kebenaran adalah operasi yang perlu dilakukan dalam setiap permintaan. Apabila ia melibatkan banyak semakan kebenaran, menanyakan pangkalan data setiap kali boleh menyebabkan kemerosotan prestasi dalam aplikasi anda. Oleh itu, menggunakan cache untuk menyimpan data kebenaran adalah pilihan yang bijak.
public function getPermissions() { return Cache::remember('permissions', 60, function () { return DB::table('permissions')->get(); }); }
Cache
Laravel untuk menyimpan dan Dapatkan data kebenaran . Kaedah ingat
menerima tiga parameter: nama kunci cache, masa tamat tempoh (dalam minit) dan fungsi tanpa nama yang digunakan untuk mendapatkan data kebenaran daripada pangkalan data. Jika data untuk kunci ini wujud dalam cache, ia diperoleh terus daripada cache, jika tidak, fungsi tanpa nama dilaksanakan dan hasilnya disimpan dalam cache. Cache
门面类来存储和获取权限数据。remember
方法接受三个参数:缓存键名、过期时间(单位为分钟)和一个匿名函数,用于从数据库中获取权限数据。如果缓存中存在该键的数据,则直接从缓存中获取,否则执行匿名函数并将结果存入缓存。
二、优化权限检查的性能
除了使用权限缓存外,我们还可以通过一些技巧来优化权限检查的性能。下面是一些优化权限检查的建议:
public function handle($request, Closure $next, $permission) { if (!auth()->user()->hasPermission($permission)) { abort(403, 'Unauthorized'); } return $next($request); }
在上面的示例中,我们通过hasPermission
方法检查当前用户是否具有所需的权限。如果用户没有权限,则中间件会返回HTTP 403错误。
AppServiceProvider
的boot
方法中实现此操作:use IlluminateSupportFacadesCache; use IlluminateSupportFacadesDB; public function boot() { $permissions = DB::table('permissions')->get(); Cache::put('permissions', $permissions, 60); }
在上面的示例中,我们通过DB
门面类从数据库中获取权限数据,并将其存入缓存。
$user = User::with('permissions')->find(1); if ($user->permissions->contains('name', 'manage_users')) { // 用户具有管理用户的权限 }
在上面的示例中,我们使用with
方法预加载用户的权限关联,并使用contains
2. Optimumkan prestasi semakan kebenaran
hasPermission code> kaedah menyemak sama ada pengguna semasa mempunyai kebenaran yang diperlukan. Jika pengguna tidak mempunyai kebenaran, perisian tengah akan mengembalikan ralat HTTP 403. <p></p>
<ol start="2"><li>Pramuat cache kebenaran: Untuk meningkatkan lagi prestasi, kami boleh pramuat cache kebenaran apabila aplikasi bermula. Operasi ini boleh dicapai dalam kaedah <code>boot
AppServiceProvider
: rrreee#🎜🎜#Dalam contoh di atas, kami lulus DB
Kelas fasad mendapatkan data kebenaran daripada pangkalan data dan menyimpannya dalam cache. #🎜🎜#with
untuk pramuat persatuan kebenaran pengguna dan gunakan kaedah mengandungi
untuk menyemak sama ada ia mempunyai kebenaran yang diperlukan. #🎜🎜##🎜🎜#Kesimpulan: #🎜🎜# Mengoptimumkan prestasi fungsi kebenaran adalah isu kritikal, terutamanya apabila berurusan dengan sejumlah besar kebenaran. Artikel ini menerangkan cara untuk meningkatkan prestasi fungsi kebenaran dalam aplikasi Laravel anda dengan menggunakan caching kebenaran dan beberapa petua pengoptimuman. Dengan melaksanakan pengesyoran ini, anda boleh mengurus dan memanfaatkan ciri kebenaran yang berkuasa dalam rangka kerja Laravel. #🎜🎜##🎜🎜# Lampiran: Contoh dalam kod adalah untuk tujuan demonstrasi sahaja dan pelaksanaan khusus mungkin berbeza bergantung pada aplikasi anda. Sila buat pengubahsuaian dan pelarasan yang sewajarnya mengikut situasi sebenar. #🎜🎜#Atas ialah kandungan terperinci Amalan Terbaik untuk Fungsi Kebenaran Laravel: Cara Melaksanakan Caching Kebenaran dan Pengoptimuman Prestasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!