이번에는 Laravel에서 비밀번호 재설정을 구현하는 단계에 대해 자세히 설명하겠습니다. Laravel에서 비밀번호 재설정을 구현하는 데 있어 주의 사항은 무엇입니까? 다음은 실제 사례입니다.
소개
이 기능을 빠르게 구현하고 싶으신가요? 새로 설치된 Laravel 애플리케이션에서 php artisan make:auth
를 실행하고(이미 이 명령을 실행한 경우 무시해도 됩니다) 브라우저에서 http://your-app.dev를 방문하세요. /register 또는 애플리케이션에 할당된 다른 URL을 사용하면 이 명령은 다음을 포함하여 사용자 로그인php artisan make:auth
(如果你已经执行过此命令,可忽略),然后在浏览器中访问 http://your-app.dev/register 或者其他分配给应用的 URL,该命令会生成用户登录注册所需要的所有东西,包括密码重置!
大多数 Web 应用都提供了为用户重置密码的功能,Laravel 也不例外,Laravel 提供了用于发送密码重置链接及实现密码重置逻辑的便捷方法,而不需要你在每个应用中自己重复实现。
注:在使用 Laravel 提供的密码重置功能之前, User 模型必须使用了 IlluminateNotificationsNotifiable trait。
数据库相关
开始之前,先验证 AppUser 模型实现了 IlluminateContractsAuthCanResetPassword
契约。当然,Laravel 自带的 AppUser 模型已经实现了该接口,并使用 IlluminateAuthPasswordsCanResetPassword trait 来包含实现该接口需要的方法。
生成重置令牌表迁移
接下来,用来存储密码重置令牌的表必须被创建,Laravel 已经自带了这张表的迁移,就存放在 database/migrations 目录。所以,你所要做的仅仅是运行迁移:
php artisan migrate
这张表就是 password_resets :
路由
Laravel 自带了 AuthForgotPasswordController
和 AuthResetPasswordController
控制器(这两个控制器类会通过 php artisan make:auth 命令自动生成),分别用于发送密码重置链接邮件和重置用户密码功能。重置密码所需的路由都已经通过 make:auth 命令自动生成了:
php artisan make:auth
对应路由定义在 IlluminateRoutingRouter 的 auth 方法中:
视图
和路由一样,重置密码所需的视图文件也通过 make:auth 命令一并生成了,这些视图文件位于
<a href="//m.sbmmt.com/wiki/61.html" target="_blank">resource</a>s/views/auth/passwords
目录下,你可以按照所需对生成的文件进行相应修改。
重置密码
定义好重置用户密码路由和视图后,只需要在浏览器中通过 /password/reset 访问这个入口路由。框架自带的 ForgotPasswordController
已经包含了发送密码重置链接邮件的逻辑, ResetPasswordController
등록에 필요한 모든 것을 생성합니다. 비밀번호 재설정!
대부분의 웹 애플리케이션은 사용자에게 비밀번호를 재설정하는 기능을 제공하며, Laravel도 예외는 아닙니다. Laravel은 각 애플리케이션에서 비밀번호를 직접 재설정하지 않고도 비밀번호 재설정 링크를 보내고 비밀번호 재설정 로직을 구현할 수 있는 편리한 방법을 제공합니다.
참고: Laravel에서 제공하는 비밀번호 재설정 기능을 사용하기 전에 사용자 모델은 IlluminateNotificationsNotifying 특성을 사용해야 합니다.
데이터베이스 관련
시작하기 전에 AppUser 모델이IlluminateContractsAuthCanResetPassword
계약을 구현하는지 확인하세요. 물론 Laravel의 자체 AppUser 모델은 이미 이 인터페이스를 구현하고 있으며 이 인터페이스를 구현하는 데 필요한 메소드를 포함하기 위해 IlluminateAuthPasswordsCanResetPassword 특성을 사용합니다.
재설정 토큰 테이블 마이그레이션 생성
🎜다음으로, 비밀번호 재설정 토큰을 저장하는 데 사용되는 테이블을 생성해야 합니다. Laravel에는 이미 이 테이블에 대한 마이그레이션이 포함되어 있으며 데이터베이스/마이그레이션 디렉터리에 저장되어 있습니다. 따라서 마이그레이션을 실행하기만 하면 됩니다: 🎜🎜php artisan migration
🎜🎜이 테이블은 비밀번호 재설정입니다: 🎜🎜 🎜🎜🎜🎜routing🎜🎜🎜🎜Laravel에는 AuthForgotPasswordController
및 A uth가 함께 제공됩니다. ResetPasswordController
컨트롤러 🎜(이 두 컨트롤러 클래스는 각각 php artisan make:auth 명령을 통해 자동으로 생성됩니다) 비밀번호 재설정 링크 이메일을 보내고 사용자 비밀번호를 재설정하는 데 사용됩니다. 비밀번호를 재설정하는 데 필요한 경로는 make:auth 명령을 통해 자동으로 생성되었습니다. 🎜🎜php artisan make:auth
🎜🎜는 경로 정의 🎜IlluminateRoutingRouter의 인증 방법에서: 🎜🎜 🎜🎜🎜🎜Views🎜🎜🎜🎜라우팅과 마찬가지로 비밀번호 재설정에 필요한 뷰 파일도 make:auth 명령을 통해 생성됩니다. 이러한 뷰 파일은 다음 위치에 있습니다. 🎜🎜<a href="//m.sbmmt.com/wiki/61.html" target="_blank">resource🎜s/views/auth/passwords </a>
디렉토리에서 생성된 파일은 필요에 따라 적절하게 수정될 수 있습니다. 🎜🎜🎜🎜Reset Password🎜🎜🎜🎜사용자 비밀번호 재설정 경로와 보기를 정의한 후 브라우저에서 /password/reset을 통해 이 입력 경로에 액세스하기만 하면 됩니다. 프레임워크와 함께 제공되는 ForgotPasswordController
에는 비밀번호 재설정 링크 이메일을 보내는 로직이 이미 포함되어 있으며 ResetPasswordController
에는 사용자 비밀번호를 재설정하는 로직이 포함되어 있습니다. 🎜🎜🎜 🎜🎜 등록 이메일을 입력하고 비밀번호 재설정 링크 보내기를 클릭하면 비밀번호 재설정 링크가 이메일 주소로 전송됩니다: 🎜🎜🎜 🎜🎜이메일을 열면 다음과 같은 비밀번호 재설정 이메일을 받게 됩니다: 🎜🎜🎜 🎜🎜 비밀번호 재설정 페이지로 들어가려면 비밀번호 재설정 버튼을 누르세요: 🎜🎜🎜🎜양식을 작성하고 제출한 후 비밀번호를 재설정할 수 있습니다.
비밀번호가 재설정되면 사용자는 자동으로 애플리케이션에 로그인되고 /home으로 리디렉션됩니다. ResetPasswordController의 RedirectTo 속성을 정의하여 성공적인 비밀번호 재설정 후 리디렉션 링크를 사용자 정의할 수 있습니다.
protected $redirectTo = '/dashboard';
protected $redirectTo = '/dashboard';
注:默认情况下,密码重置令牌一小时内有效,你可以通过修改 config/auth.php 文件中的选项 expire 来改变有效时间。
自定义
自定义认证 Guard
在配置文件 auth.php 中,可以配置多个“guards”,以便用于实现基于多用户表的独立认证,你可以通过重写内置的 ResetPasswordController 控制器上的 guard 方法来使用你所选择的 guard,该方法将会返回一个 guard 实例:
use Illuminate\Support\Facades\Auth; protected function guard() { return Auth::guard('guard-name'); }
自定义密码 broker
在配置文件 auth.php 中,可以配置多个密码,以便用于重置多个用户表的密码 broker,同样,可以通过重写自带的 ForgotPasswordController 和 ResetPasswordController 控制器中的 broker 方法来使用你所选择的 broker:
use IlluminateSupportFacadesPassword;
/** * 获取密码重置期间所使用的broker. * * @return PasswordBroker * @translator laravelacademy.org */ protected function broker() { return Password::broker('name'); }
自定义密码重置邮件
你可以很方便地编辑发送密码重置链接给用户的通知类实现自定义密码重置邮件,要实现这一功能,需要重写 User 模型上的 sendPasswordResetNotification
설정 파일 auth.php에서 여러 "가드"를 구성할 수 있습니다. 다중 사용자 테이블을 기반으로 하는 인증의 경우 내장된 ResetPasswordController 컨트롤러의 가드 메서드를 재정의하여 원하는 가드를 사용할 수 있습니다. 이는 가드 인스턴스를 반환합니다:
/** * 发送密码重置通知. * * @param string $token * @return void */ public function sendPasswordResetNotification($token) { $this->notify(new ResetPasswordNotification($token)); }
auth.php 구성 파일에서 여러 사용자 테이블의 비밀번호 브로커를 재설정하기 위해 여러 비밀번호를 구성할 수 있습니다. 마찬가지로 다음과 같이 원하는 브로커를 사용할 수 있습니다. 내장된 ForgotPasswordController 및 ResetPasswordController 컨트롤러의 브로커 메소드 재정의:
use IlluminateSupportFacadesPassword;
sendPasswordResetNotification
메소드를 다시 작성해야 합니다. , 원하는 알림 클래스를 사용하여 알림을 보낼 수 있습니다. 이 방법으로 수신되는 첫 번째 매개변수는 비밀번호 재설정 $token입니다. 🎜rrreee🎜 이 글의 경우에는 이 방법을 마스터하셨습니다. 자세한 내용은 PHP 중국어 웹사이트의 다른 관련 기사를 주목해 주세요! 🎜🎜추천 자료: 🎜🎜🎜Laravel은 Redis를 사용하여 세션 단계를 자세히 공유합니다.🎜🎜🎜🎜🎜php 재귀 함수 사례 사용 세부 정보🎜🎜🎜위 내용은 Laravel에서 비밀번호 재설정을 구현하는 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!