【问题标题】:How to use laravel inbuild auth module with email verification如何使用带有电子邮件验证的 laravel inbuild auth 模块
【发布时间】:2016-12-29 22:27:54
【问题描述】:

我通过php artisan make:auth创建了身份验证模块

我在邮件验证后尝试转换注册成功,但发现所有验证码都在供应商文件夹中。

以下路线

 // Authentication Routes...
    Route::get('login', 'Auth\AuthController@showLoginForm');
    Route::post('login', 'Auth\AuthController@login');
    Route::get('logout', 'Auth\AuthController@logout');

    // Registration Routes...
    Route::get('register', 'Auth\AuthController@showRegistrationForm');
    Route::post('register', 'Auth\AuthController@register');

    // Password Reset Routes...
    Route::get('password/reset/{token?}', 'Auth\PasswordController@showResetForm');
    Route::post('password/email', 'Auth\PasswordController@sendResetLinkEmail');
    Route::post('password/reset', 'Auth\PasswordController@reset');

它直接创建用户和登录。但我想通过发送带有令牌的电子邮件来验证用户的电子邮件。

我知道在供应商中更新不是一个好主意,请建议我处理这个问题,或者我应该创建自己的身份验证模块?

感谢您的宝贵时间, 干杯。

【问题讨论】:

  • 如果可以通过扩展它会更好,如果不创建你自己的。 :)
  • 您的意思是哪个代码在供应商文件夹中?在 AuthController 中创建新用户。
  • @MinaAbadir 我说的是“注册”方法
  • 是的,我的意思是注册方法,它在 AuthController 中。
  • 很抱歉只有两种方法存在createvalidator

标签: php laravel authentication laravel-5.2 laravel-authorization


【解决方案1】:

注册过程通过trait内部的方法register

 /**
 * Handle a registration request for the application.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return \Illuminate\Http\Response
 */
public function register(Request $request)
{
    $validator = $this->validator($request->all());

    if ($validator->fails()) {
        $this->throwValidationException(
            $request, $validator
        );
    }

    Auth::guard($this->getGuard())->login($this->create($request->all()));

    return redirect($this->redirectPath());
}

那么这个方法就是调用app目录下AuthController中的两个函数,你可以随意编辑:

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'name' => 'required|max:255',
            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|confirmed|min:6',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        $user = User::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
            //'token' => str_random(10)
        ]);

        //Send email to $user here
        return $user

    }
}

为了防止用户登录,更改Auth中间件:

class Authenticate
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @param  string|null  $guard
     * @return mixed
     */
    public function handle($request, Closure $next, $guard = null)
    {
        if (Auth::guard($guard)->guest()) {
            if ($request->ajax()) {
                return response('Unauthorized.', 401);
            } else {
                return redirect()->guest('login');
            }
        }

        if (!Auth::user()->validated())
        {
            return redirect()->route('error.message.route');
        }
        return $next($request);
    }
}

【讨论】:

  • 抱歉,我没有发现任何新内容。
  • 字段通过验证器方法进行验证。然后在 create 方法中,你可以使用任何你想要的逻辑。
  • 在创建中添加了一些关于如何发送电子邮件的 cmets。
  • 我不会运行,因为 `Auth::guard($this->getGuard())->login($this->create($request->all())); `
  • 收到错误Argument 1 passed to Illuminate\Auth\SessionGuard::login() must implement interface Illuminate\Contracts\Auth\Authenticatable, null given, called in C:\xampp\htdocs\pathonnet.com\vendor\laravel\framework\src\Illuminate\Foundation\Auth\RegistersUsers.php on line 63 and defined
猜你喜欢
  • 2022-01-24
  • 1970-01-01
  • 1970-01-01
  • 2021-12-13
  • 2017-02-20
  • 1970-01-01
  • 2020-03-18
  • 2018-12-15
  • 1970-01-01
相关资源
最近更新 更多