[Laravel 5.3 新功能] 7. 图片尺寸表单验证规则

说明

此文章是 [Laravel 5.3 新功能] 系列的第七篇文章,图片尺寸表单验证规则。

[Laravel 5.3 新功能] 系列完整文章列表请见:分享:[Laravel 5.3 新功能] 系列文章

正文

在 Laravel 5.3 中,新增了图片尺寸验证规则,该规则名称为 dimensions ,你可以传递以下参数到验证规则里:

  • min_width:宽度比这个尺寸小的图片将会被拒绝
  • max_width:宽度比这个尺寸大的图片将会被拒绝
  • min_height:高度比这个尺寸小的图片将会被拒绝
  • max_height:高度比这个尺寸大的图片将会被拒绝
  • width:宽度不等于这个尺寸的图片将会被拒绝
  • height:高度不等于这个尺寸的图片将会被拒绝
  • ratio:宽高比不等于这个值的图片将会被拒绝

你也可以组合使用这些规则,如定义一个简单的路由规则:

// routes file
Route::get('/', function () {
    return view('form');
});

Route::post('/', 'ImageController@postImage');
<!--form.blade.php-->
<form method="POST" enctype="multipart/form-data">
    <input type="file" name="avatar">
    <input type="submit">
</form>

现在让我们来编写控制器 ImageController 的验证规则代码:

// ImageController
    public function postImage(Request $request)
    {
        $this->validate($request, [
             'avatar' => 'dimensions:min_width=250,min_height=500'
        ]);

        // or... 

        $this->validate($request, [
             'avatar' => 'dimensions:min_width=500,max_width=1500'
        ]);

        // or...

        $this->validate($request, [
             'avatar' => 'dimensions:width=100,height=100'
        ]);

        // or...

        // Ensures that the width of the image is 1.5x the height
        $this->validate($request, [
             'avatar' => 'dimensions:ratio=3/2'
        ]);
    }

这就完成图片尺寸的验证功能了,接下来只要完善好业务逻辑即可。

全文完。

链接

本帖已被设为精华帖!
本帖由系统于 2年前 自动加精
monkey
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

社区文档:

将托管在 packagist.org 和 github.com 的扩展包使用国内 CDN 加速
GitHub Laravel 扩展包 TOP 250
速查表方便快速查询框架功能,支持手机访问,支持中英文版本
Laravel 中文文档,由社区用户翻译和维护,将会保持一直更新
此文档的目的,就是为了提高技术团队的凝聚力、一致性和生产效率。
开发环境的部署,开发者工具的选择,适用于 Mac 和 Windows。
浓缩过后的精华
Laravel Nova 后台管理面板文档的中文翻译
Lumen 中文文档,由社区用户翻译和维护,将会保持一直更新
Laravel 下知名扩展包 Dingo API 的中文文档,Laravel API 开发必知必会