laravel php验证码 表单字段验证 自定义验证报错信息

9 篇文章 0 订阅

验证码导入:

  1. 命令行运行composer require mews/captcha 安装依赖包(需要php>=5.4,php.ini开启GD库)
  2. config\app.php的providers里加上Mews\Captcha\CaptchaServiceProvider::class,
  3. config\app.php的aliases里加上’Captcha’ => Mews\Captcha\Facades\Captcha::class,
  4. 命令行运行php artisan vendor:publish,输入Provider: Mews\Captcha\CaptchaServiceProvider的序号后回车,生成config\captcha.php,可修改此文件控制验证码的生成
  5. controller里validate函数设置字段验证规则和报错信息

参考https://qiita.com/gone0021/items/5699c29c7ce64f08b8d2
如果表单字段验证不通过,下面的代码可以在页面上显示不通过的原因

@if(count($errors)>0)
	@foreach($errors->all() as $e)
		{{ $e }}<br/>
	@endforeach
@endif
//resources\views\test\v3.blade.php
@extends('mytemplate.parent')
@section('part1')
@if(count($errors)>0)
	@foreach($errors->all() as $e)
		{{ $e }}<br/>
	@endforeach
@endif

<form method="post" action="{{ route('v4r') }}" enctype="multipart/form-data">
    <!--  方式1:laravel 5.6 及以后版本,也是 csrf_field() 的简写 -->
    <!-- @csrf -->
    <!-- 方式2:laravel 5.6 以下老版本  -->
    <!-- {{ csrf_field() }} -->
    <!--  方式3:添加隐藏字段-->
    <input name="_token" type="hidden" value="<?php echo csrf_token(); ?>">
    <!-- 输出上面的 token 字符串 -->
    {{ csrf_token() }}<br />
    name:<input type='text' name="name" value='111' /><br />
    age:<input type='text' name="age" value='3' /><br />
    email:<input type='text' name="email" value='2@2' /><br />
    file:<input type='file' name="file1" /><br />
    capture:<input type='text' name="cap" /><br />
    <img src="{{captcha_src()}}" style="cursor: pointer" onclick="this.src='{{captcha_src()}}'+Math.random()">
    <input type='submit' value='Submit' />
</form>
@endsection
@section('part2')
<?php
echo '<form method="post" action="' . route('v4r') . '" enctype="multipart/form-data">';
echo '<input name="_token" type="hidden" value="' . csrf_token() . '">';
echo '<input type="text" name="id" value="enter name"/>';
echo '<input type="file" name="file1"/>';
echo '<input type="submit" value="Submit"/></form>';
?>
@endsection
//app\Http\Controllers\TestViewController.php
 public function v4(Request $request)
    {
        $validate_rule = [
            'name' => 'required|min:2|max:4',
            'age' => 'required|numeric|min:2|max:4',
            'email' => 'required|email',
            'file1' => 'required|file',
            'cap' => 'required|captcha',
        ];
        $validate_msg = [
            'name.required' => '名前を入力してください',
            'age.numeric' => '整数で入力してください',
            'cap.captcha' => '验证码错误',
        ];
        // 参数2($validate_msg)可以不传
        // $request->validate($validate_rule);
        $request->validate($validate_rule, $validate_msg);

        $fn = 'file1';
        if ($request->hasFile($fn) && $request->file($fn)->isValid()) {
            $fname = md5(time()) . rand(100, 999) . '.' . $request->file($fn)->getClientOriginalExtension();
            echo  $fname;
            //会上传到\public\upload
            // $request->file($fn)->move('./upload', $fname);
            $request->file($fn)->move(getcwd() . '/upload', $fname);
        } else {
            echo $request->file($fn)->getError() . '<br/>';
            echo $request->file($fn)->getErrorMessage() . '<br/>';
        }
        return view('test.v4');
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值