gpt4 book ai didi

Laravel 自动生成验证的实例讲解:login / logout

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Laravel 自动生成验证的实例讲解:login / logout由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

Laravel 自动授权讲解 。

看到这部分文档,经常看见的一句话就是php artisan make:auth,经常好奇这段代码到底干了什么,现在就来扒一扒.

路由 。

路由文件中会新加入以下内容:

?
1
2
Auth::routes();
Route::get( '/home' , 'HomeController@index' )->name( 'home' );

首先先是Auth::route();,这句代码等于以下全部设置(文件位置是\Illuminate\Routing\Router.php):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/**
   * Register the typical authentication routes for an application.
   *
   * @return void
   */
  public function auth()
  {
   // Authentication Routes...
   $this ->get( 'login' , 'Auth\LoginController@showLoginForm' )->name( 'login' );
   $this ->post( 'login' , 'Auth\LoginController@login' );
   $this ->post( 'logout' , 'Auth\LoginController@logout' )->name( 'logout' );
 
   // Registration Routes...
   $this ->get( 'register' , 'Auth\RegisterController@showRegistrationForm' )->name( 'register' );
   $this ->post( 'register' , 'Auth\RegisterController@register' );
 
   // Password Reset Routes...
   $this ->get( 'password/reset' , 'Auth\ForgotPasswordController@showLinkRequestForm' )->name( 'password.request' );
   $this ->post( 'password/email' , 'Auth\ForgotPasswordController@sendResetLinkEmail' )->name( 'password.email' );
   $this ->get( 'password/reset/{token}' , 'Auth\ResetPasswordController@showResetForm' )->name( 'password.reset' );
   $this ->post( 'password/reset' , 'Auth\ResetPasswordController@reset' );
  }

这一部分先讲注册,首先,可以看到登录(login)的路由指向的是Auth\LoginController@showLoginForm,这个控制器是app\Http\Auth\LoginController.php,这里贴一下他的代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
class LoginController extends Controller
{
  /*
  |--------------------------------------------------------------------------
  | Login Controller
  |--------------------------------------------------------------------------
  |
  | This controller handles authenticating users for the application and
  | redirecting them to your home screen. The controller uses a trait
  | to conveniently provide its functionality to your applications.
  |
  */
 
  use AuthenticatesUsers;
 
  /**
   * Where to redirect users after login.
   *
   * @var string
   */
  protected $redirectTo = '/home' ;
 
  /**
   * Create a new controller instance.
   *
   * @return void
   */
  public function __construct()
  {
   $this ->middleware( 'guest' )->except( 'logout' );
  }
}

而其中并没有设置showLoginForm方法,该方法被保存在trait AuthenticatesUsers中,该方法的代码如下:

?
1
2
3
4
public function showLoginForm()
  {
   return view( 'auth.login' );
  }

就是返回一个视图,下面我们来看该视图:

?
1
2
<form class = "form-horizontal" method= "POST" action= "{{ route('login') }}" >
</form>

而其中最重要的就是看这个表单被提交到了哪里,结合上面的路由表,可以看到是 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
public function login(Request $request )
  {
   $this ->validateLogin( $request );
   /**
   *
   protected function validateLogin(Request $request)
  {
   $this->validate($request, [
    $this->username() => 'required|string',
    'password' => 'required|string',
   ]);
  }
   其中 $this->username() 就是 return 'email';
   **/
   // 限制请求次数,防止暴力破解的
   if ( $this ->hasTooManyLoginAttempts( $request )) {
    $this ->fireLockoutEvent( $request );
 
    return $this ->sendLockoutResponse( $request );
   }
   /**
   // 关于 attempt 的介绍可以看我上一篇博客
   protected function attemptLogin(Request $request)
  {
   return $this->guard()->attempt(
    $this->credentials($request), $request->has('remember')
   );
  }
  **/
   // 如果验证通过的话
   if ( $this ->attemptLogin( $request )) {
    return $this ->sendLoginResponse( $request );
   }
   // 否则的话增加验证的统计次数
   $this ->incrementLoginAttempts( $request );
   // 返回错误信息
   return $this ->sendFailedLoginResponse( $request );
  }

可以看到验证的重点还是Auth::attempt()函数,而且默认是使用email进行验证.

退出操作的代码如下:

?
1
2
3
4
5
6
7
8
public function logout(Request $request )
  {
   $this ->guard()->logout();
 
   $request ->session()->invalidate();
 
   return redirect( '/' );
  }

$this->guard()的代码如下:

?
1
2
3
4
protected function guard()
  {
   return Auth::guard();
  }

logout的具体的执行代码如下,别问我怎么找到的,PHPStorm的全项目文本搜索不解释:\Illuminate\Auth\SessionGuard.php:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
public function logout()
  {
   $user = $this ->user();
 
   $this ->clearUserDataFromStorage();
 
   if (! is_null ( $this ->user)) {
    $this ->cycleRememberToken( $user );
   }
 
   if (isset( $this ->events)) {
    $this ->events->dispatch( new Events\Logout( $user ));
   }
 
   // Once we have fired the logout event we will clear the users out of memory
   // so they are no longer available as the user is no longer considered as
   // being signed into this application and should not be available here.
   $this ->user = null;
 
   $this ->loggedOut = true;
  }

其中牵扯很多,那么我换种角度考虑,假设我们不考虑logout()的具体实现,而是思考如何制作自己的退出设置,那么该如何修改源码呢?好像直接修改成下面的形式就可以了:

?
1
2
3
4
5
6
7
8
public function logout(Request $request )
  {
   Auth::guard()->logout();
 
   $request ->session()->invalidate();
   // 自定义重定向地址
   return redirect( '/' );
  }

其中的很多内容都跟我们的设置无关,全自动的调用,所以我们的退出按钮就只需要运行上述代码即可。本人请测有效.

以上这篇Laravel 自动生成验证的实例分析:login / logout就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.

原文链接:https://blog.csdn.net/YQXLLWY/article/details/75738646 。

最后此篇关于Laravel 自动生成验证的实例讲解:login / logout的文章就讲到这里了,如果你想了解更多关于Laravel 自动生成验证的实例讲解:login / logout的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com