- Laravel Application Development Cookbook
- Terry Matula
- 273字
- 2021-07-23 15:33:35
Restricting access to certain pages
In this recipe, we'll explore how to restrict access to various pages in our app. This way, we can make pages viewable to only those with the correct credentials.
Getting ready
We will be using the code created in the Setting up and configuring the Auth library and Creating an authentication system recipes as the basis for this recipe.
How to do it...
To complete this recipe, follow these steps:
- Create a filter in our
filters.php
file that checks for logged-in users. The default Laravelauth
filter will be fine:Route::filter('auth', function() { if (Auth::guest()) return Redirect::guest('login'); });
- Create a filter in
filter.php
for checking if a user is an admin:Route::filter('auth_admin', function() { if (Auth::guest()) return Redirect::guest('login'); if (Auth::user()->admin != TRUE) return Redirect::to('restricted'); });
- Make a route that we restrict to logged-in users:
Route::get('restricted', array('before' => 'auth', function() { return 'This page is restricted to logged-in users! <a href="admin">Admins Click Here.</a>'; }));
- Make a route that is restricted to admins:
Route::get('admin', array('before' => 'auth_admin',function() { return 'This page is restricted to Admins only!'; }));
How it works...
Filters are a powerful part of Laravel and can be used to simplify many tasks. The default auth
filter that comes with Laravel simply checks if a user is logged in or not and, if not, redirects him/her to the login page. In our restricted
route, we add the auth
filter to run before the function is executed.
Our auth_admin
filter checks to make sure the user is logged in and also checks if the user is set as admin
. If not, he/she is redirected back to the normal restricted page.
- 物聯網工程規劃技術
- Getting Started with WebRTC
- Socket.IO Real-time Web Application Development
- Building RESTful Web services with Go
- 通信原理及MATLAB/Simulink仿真
- 通信十年:擁抱互聯網
- 轉化:提升網站流量和轉化率的技巧
- Guide to NoSQL with Azure Cosmos DB
- 物聯網傳感器技術與應用
- 物聯網商業設計與案例
- 學術虛擬社區用戶社會化交互行為研究
- LiveCode Mobile Development Beginner's Guide
- 深入理解移動互聯網
- 創新力:中國網絡創新研究
- 校園網絡規劃與架設