二、后台超级管理员完善密码修改功能

(1)添加路由(在admin.login中间件)php

Route::any('pass','IndexController@pass');

(2) IndexController.php中添加pass方法数据库

注意Input、Crypt、User的引用数组

先判断新密码是否符合要求以及确认密码,此时若错误,返回的是对象;ui

以后再查询数据库,判断原密码是否正确,此时错误返回的是字符串url

use App\Http\Model\User;
use Illuminate\Support\Facades\Input;
use Validator;
use Crypt;

 

 1  public function pass()
 2     {
 3         if($input = Input::all()){
 4             //定义每一个字段的要求
 5             $rules = [
 6                 'password'=>'required|between:6,20|confirmed', 
 7                 //不能为空;字符在6-20;与确认密码进行验证;
 8                 //修改pass.blade.php中确认密码的name,将 password_c改成password_confirmation
 9             ];
10             //从新定义错误信息,格式: '字段.属性'=>'信息'
11             $messages = [
12                 'password.required'=>'新密码不能为空', 
13                 'password.between'=>'新密码6-20位',
14                 'password.confirmed'=>'新密码与确认密码不一致'
15             ];
16             $validator = Validator::make($input,$rules,$messages);
17             //利用$validator进行验证,若是新密码与确认密码一致,将获取输入的原密码与数据库中的密码比较,若密码相等,将经过验证,更新为新密码
18             if($validator->passes()){
19                 $user = User::first();
20                 $pass = Crypt::decrypt($user->user_pass);
21                 if($pass==$input['password_o']){
22                     $user->user_pass = Crypt::encrypt($input['password']);
23                     $user->update();
24                     return back()->with('errors','密码修改为功!'); //为了方便,仍然用errors传递25                 }else{
26                     //若原密码错误,将返回一个变量到errors中,只是一个字符串
27                     return back()->with('errors','原密码错误');
28                 }
29             }else{
30                 //若原密码、确认密码没有经过验证,则利用withErrroes($validator)保存错误信息到errors对象中,并返回到pass.blade.php,因此pass.blade.php须要将其接收
31                 //dd($validator->errors()->all());
32                 return back()->withErrors($validator);
33             }
34 
35         }else{
36             return view('admin.pass');
37         }
38         
39     }

 

(3)pass.blade.php接收错误信息spa

count($errors)返回数组中元素的个数或是类的属性的个数,如若为字符串返回1; code

大于0代表有错误返回,is_object()判断变量是否为对象,是则进行遍历,不然直接输出信息中间件

在<h3>修改密码</h3>后面对象

 

        @if(count($errors)>0)
        <div class="mark">
            @if(is_object($errors))
                @foreach($errors->all() as $error)
                <p>{{$error}}</p>
                @endforeach
            @else
                <p>{{$errors}}</p>
            @endif
        </div>
     @endif

(4)修改index.blade.php中修改密码按钮blog

<li><a href="{{url('admin/pass')}}" target="main">修改密码</a></li>

验证:

首先将新密码与确认密码故意输错

 

再次输入新密码与确认密码符合要求,将原密码输错

再次所有输入正确