请问一下登录的验证码问题?

我按照注册的方法在SessionsController.php中代码如下:

public function store(Request $request)
    {
        $credentials = $this->validate($request, [
            'login_name' => 'required|max:100',
            'password' => 'required',
            'captcha' => 'required|captcha'
        ], [
            'captcha.required' => '验证码 不能为空',
            'captcha.captcha' => '请输入正确的验证码',
        ]);
        if (Auth::attempt($credentials, $request->has('remember'))) {
            session()->flash('success', '欢迎登录XX管理平台,祝你每天都拥有好心情!');
            return redirect()->route('home');
        } else {
            session()->flash('danger', '很抱歉,您的用户名和密码不匹配');
            return redirect()->back();
        }

        return;
    }

但是我这里报错如下:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'captcha' in 'where clause' (SQL: select * from users where login_name = Tyler and captcha = 6a2n2u limit 1)
想问下登录的时候验证码怎么做,是先判断验证码,然后验证码通过在执行后面一步吗

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案
public function store(Request $request)
    {
        $this->validate($request, [
            'login_name' => 'required|max:100',
            'password' => 'required',
            'captcha' => 'required|captcha'
        ], [
            'captcha.required' => '验证码 不能为空',
            'captcha.captcha' => '请输入正确的验证码',
        ]);
        if (Auth::attempt($request->only('login_name','password'), $request->has('remember'))) {
            session()->flash('success', '欢迎登录XX管理平台,祝你每天都拥有好心情!');
            return redirect()->route('home');
        } else {
            session()->flash('danger', '很抱歉,您的用户名和密码不匹配');
            return redirect()->back();
        }

        return;
    }

这样呢?

6年前 评论
讨论数量: 3
public function store(Request $request)
    {
        $this->validate($request, [
            'login_name' => 'required|max:100',
            'password' => 'required',
            'captcha' => 'required|captcha'
        ], [
            'captcha.required' => '验证码 不能为空',
            'captcha.captcha' => '请输入正确的验证码',
        ]);
        if (Auth::attempt($request->only('login_name','password'), $request->has('remember'))) {
            session()->flash('success', '欢迎登录XX管理平台,祝你每天都拥有好心情!');
            return redirect()->route('home');
        } else {
            session()->flash('danger', '很抱歉,您的用户名和密码不匹配');
            return redirect()->back();
        }

        return;
    }

这样呢?

6年前 评论

@FMW 是正确的,我这样写的感觉你这个更加简洁看着舒服

$credentials = $this->validate($request, [
            'login_name' => 'required|max:100',
            'password' => 'required',
        ]);

        $this->validate($request,[
            'captcha' => 'required|captcha'
        ], [
            'captcha.required' => '验证码 不能为空',
            'captcha.captcha' => '请输入正确的验证码',
        ]);

        if (Auth::attempt($credentials, $request->has('remember'))) {
            session()->flash('success', '欢迎登录XX管理平台,祝你每天都拥有好心情!');
            return redirect()->route('home');
        } else {
            session()->flash('danger', '很抱歉,您的用户名和密码不匹配');
            return redirect()->back();
        }
6年前 评论

@nicetyler 你那样写的问题出在attempt的第一个参数,第一个参数传进去一个数组,这个函数会根据这个数组里除了password键的其他键,去用户表里搜索,所以你把captcha传进去了,自然就报错了,除非你把验证码字段存到了用户表里。

6年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!