美文网首页
9月20日知识点记录

9月20日知识点记录

作者: 默言1024 | 来源:发表于2017-09-20 19:06 被阅读0次

    一.Laravel表单验证

    创建控制器并在添加方法shore()中编写验证

     public function store(Request $request)
    {
        // 验证以及保存提交的数据...
    }
    

    编写验证逻辑

    validate 方法会接收 HTTP 传入的请求以及验证的规则。如果验证通过,你的代码就可以正常的运行。若验证失败,则会抛出异常错误消息并自动将其返回给用户。在一般的 HTTP 请求下,都会生成一个重定向响应,对于 AJAX 请求则会发送 JSON 响应

    public function store(Request $request)
    {
        $this->validate($request, [
            'title' => 'required|unique:posts|max:255',//标题不为空,post提交,最长255
            'body' => 'required',//主要内容不为空
        ]);
    
        //成功上传新数据,将其保存到数据库...    
    }
    

    嵌套属性

       $this->validate($request, [
           'title' => 'required|unique:posts|max:255',
           'author.name' => 'required',//在验证规则中使用「点」语法来指定他们
           'author.description' => 'required',
       ]);
    

    显示验证错误

    Laravel 会自动把用户重定向到先前的位置。另外,所有的验证错误会被自动 闪存至 session
    $errors 变量在每次请求的所有视图中都可以被使用,你可以很方便的假设 $errors 变量已被定义且进行安全地使用

    if (count($errors) > 0)
        <div class="alert alert-danger">
            <ul>
                @foreach ($errors->all() as $error)
                    <li>{{ $error }}</li>//在视图中显示错误的消息
                @endforeach
            </ul>
        </div>
    @endif
    

    自定义闪存的错误消息格式

    在控制器中重写 formatValidationErrors。别忘了将 Illuminate\Contracts\Validation\Validator 类引入到文件上方

    <?php
    
    namespace App\Http\Controllers;
    
    use Illuminate\Foundation\Bus\DispatchesJobs;
    use Illuminate\Contracts\Validation\Validator;
    use Illuminate\Routing\Controller as BaseController;
    use Illuminate\Foundation\Validation\ValidatesRequests;
    
    abstract class Controller extends BaseController
    {
        use DispatchesJobs, ValidatesRequests;
    
        /**
         * {@inheritdoc}
         */
        protected function formatValidationErrors(Validator $validator)
        {
            return $validator->errors()->all();
        }
    }
    

    表单请求验证

    表单请求是一个自定义的请求类,里面包含着验证逻辑。要创建一个表单请求类,可使用 Artisan 命令行命令 make:request
    php artisan make:request StoreBlogPostRequest
    新生成的类文件会被放在 app/Http/Requests 目录下
    public function rules() { return [ 'title' => 'required|unique:posts|max:255', 'body' => 'required', ]; }
    在控制器方法中利用类型提示传入请求。传入的请求会在控制器方法被调用前进行验证,意思就是说你不会因为验证逻辑而把控制器弄得一团糟

    /**
     * 保存传入的博客文章。
     *
     * @param  StoreBlogPostRequest  $request
     * @return Response
     */
    public function store(StoreBlogPostRequest $request)
    {
        // 传入的请求是有效的...
    }
    

    如果验证失败,就会生成一个重定向响应把用户返回到先前的位置。这些错误会被闪存到 session,所以这些错误都可以被显示

    授权表单请求

    表单的请求类内包含了 authorize 方法。在这个方法中,你可以确认用户是否真的通过了授权,以便更新指定数据

    /**
     * 判断用户是否有权限做出此请求。
     *
     * @return bool
     */
    public function authorize()
    {
        $commentId = $this->route('comment');
    
        return Comment::where('id', $commentId)
                      ->where('user_id', Auth::id())->exists();
    }
    

    自定义闪存的错误消息格式
    自定义验证失败时闪存到 session 的验证错误格式,可在你的基底请求 (App\Http\Requests\Request) 中重写 formatErrors,文件上方引入 Illuminate\Contracts\Validation\Validator 类

    /**
     * {@inheritdoc}
     */
    protected function formatErrors(Validator $validator)
    {
        return $validator->errors()->all();
    }
    

    自定义错误消息
    (你可以通过重写表单请求的 messages 方法来自定义错误消息。此方法必须返回一个数组,其中含有成对的属性或规则以及对应的错误消息)

    /**
     * 获取已定义验证规则的错误消息。
     *
     * @return array
     */
    public function messages()
    {
        return [
            'title.required' => '标题是必填的',
            'body.required'  => '消息是必填的',
        ];
    }
    

    处理错误消息
    调用一个 Validator 实例的 errors 方法,会得到一个 Illuminate\Support\MessageBag 的实例,里面有许多可让你操作错误消息的便利方法
    $messages = $validator->errors(); echo $messages->first('email')//查看特定字段的第一个错误消息
    foreach ($messages->get('email') as $message) { //查看特定字段的所有错误消息,取所有消息中的一个数组,可以使用 get 方法 }
    foreach ($messages->all() as $message) { //查看所有字段的所有错误消息 }
    if ($messages->has('email')) { //判断特定字段是否含有错误消息 }
    echo $messages->first('email', '<p>:message</p>');//获取格式化后的错误消息
    foreach ($messages->all('<li>:message</li>') as $message) { //获取所有格式化后的错误消息 }

    自定义错误消息

    通过传递三个参数到 Validator::make 方法来自定义验证消息

    $messages = [
        'required' => ':attribute 的字段是必要的。',//:attribute 占位符会被通过验证的字段实际名称所取代
    ];
    
    $validator = Validator::make($input, $rules, $messages);
    

    指定自定义消息到特定的属性
    $messages = [ 'email.required' => '我们需要知道你的 e-mail 地址!',//属性名称后加上「.」符号和指定验证的规则 ];

    可用的验证规则<----#---->点我

    二.重要知识点

    1.随机数(PHP7)

    random_bytes 函数返回 string 类型,并接受一个 int 类型为参数,该参数规定了所返回字符串的字节长度
    $bytes = random_bytes('10'); var_dump(bin2hex($bytes));//bin2hex() 函数把 ASCII 字符的字符串转换为十六进制值。字符串可通过使用 pack() 函数再转换回去 //possible ouput: string(20) "7dfab0af960d359388e6"
    random_int 函数返回给定范围内的整型数
    var_dump(random_int(1, 100)); //possible output: 27

    2.毫秒级时间戳

    <?php
    function getMillisecond() {
    list($t1, $t2) = explode(' ', microtime());//microtime() 函数返回当前 Unix 时间戳的微秒数,explode() 函数把字符串打散为数组,list() 函数用于在一次操作中给一组变量赋值
    return (float)sprintf('%.0f',(floatval($t1)+floatval($t2))*1000);//sprintf() 函数把格式化的字符串写入变量中,floatval ()获取变量的浮点值,(float)获取变量的浮点值
    }
    

    echo getMillisecond();

    3.UUID(唯一识别码)

    http://www.jianshu.com/p/792c2bbe107e

    4.动态获取文件后缀

    $ext = $file->getClientOriginalExtension();

    5.文件类型表单验证

    self::validate($request, [
                'img' => 'required|mimes:jpeg,bmp,png,gif,jpg',
                'photoName' => 'required|string|min:6|max:10'
            ]);
    

    6.更换中文错误提示信息

    复制resources/lang/en/validation.php文件到自己新建的zh-cn目录
    然后替换其中的内容https://laravel-china.org/articles/5840/validation-validation-in-laravel-returns-chinese-prompt

    'attributes' => [
        'name'          => '名字',
        'age'           => '年龄',
        'img'           => '图片',
        'photoName'     => '图片名称',
        'user_name' => '姓名',
        'pwd' => '密码',
        'sex' => '性别',//添加自定义字段
        ],
    

    7.Laravel时间区修改

    在config/app.php修改该字段
    'timezone' => 'PRC',//把原来的TRC改为PRC

    8.自定义配置使用

    在config下新建一个存放配置的PHP文件

    <?php
    return [
        'upload_dir' => public_path() . '/uploads',//上传图片的路径
       ];
    

    在页面中调用:
    config('sys.upload_dir')

    相关文章

      网友评论

          本文标题:9月20日知识点记录

          本文链接:https://www.haomeiwen.com/subject/zfensxtx.html