总结laravel框架使用过程踩过得那些坑儿

之前一直用CI框架,最近换laravel,小白总结一下使用过程的踩过得坑。

1.表单验证Validate

使用表单验证发现不加required等强制条件的时候,其他限制条件对null有效,空串无效,如下图:

总结laravel框架使用过程踩过得那些坑儿_第1张图片

查阅其代码可以,对空串不验证

总结laravel框架使用过程踩过得那些坑儿_第2张图片

2.请求Request

当前端使用ajax传值,类型为json.如果传空值,
$request->post(),接受结果为空串,
$request->all(),$request->input(),接受结果为null。如下图:

总结laravel框架使用过程踩过得那些坑儿_第3张图片

后来发现底层会对json会处理,过滤空串为null赋值给ParameterBag类的$parameters,input和all都直接取此值,post是通过request。

3.数据无更新时update的返回结果

使用update封装sql批量修改数据,无更新结果返回0,

使用update传数组,单条修改数据如无特殊设置,会自动更新updated_at字段,故结果永远返回1

4.上传文件类型

laravel的表单验证中文件类型的后缀名判断是通过mime类型,mime类型对办公文件的处理会由于文件来源等不同,结果不同,使用需慎重。

总结laravel框架使用过程踩过得那些坑儿_第4张图片

可通过修改magic文件改变结果

总结laravel框架使用过程踩过得那些坑儿_第5张图片

总结laravel框架使用过程踩过得那些坑儿_第6张图片

5.数据库的严格模式。

在config的database中如果配置了strict 为true会按照严格模式,如超出字段值长度会直接报错。

总结laravel框架使用过程踩过得那些坑儿_第7张图片

    protected function strictMode()
    {
        return "set session sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'";
    }

总结laravel框架使用过程踩过得那些坑儿_第8张图片

6.最后一条是关于php的,??的作用相当于isset,对空串,0不起作用,切记

你可能感兴趣的:(php编程)