当前位置:首页 > 文章列表 > 文章 > php教程 > Laravel多数值求和验证方法

Laravel多数值求和验证方法

2025-11-20 13:28:55 0浏览 收藏

有志者,事竟成!如果你在学习文章,那么本文《Laravel 中如何验证多个数值输入之和?》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

Laravel 中如何验证多个数值输入之和?

本文介绍了如何在 Laravel 中验证多个数值输入字段的总和是否等于特定值。通过自定义验证规则,可以方便地在表单验证中实现此功能,确保数据的准确性和完整性。文章提供了详细的代码示例和使用方法,帮助开发者快速掌握该技巧。

在 Web 开发中,经常会遇到需要验证多个数值字段总和的情况,例如,在分配百分比时,需要确保所有百分比之和为 100%。Laravel 框架提供了强大的验证功能,但默认情况下并没有直接支持验证多个字段之和的功能。本文将介绍如何通过自定义验证规则来实现这一需求。

自定义验证规则

Laravel 允许开发者通过 Validator::extend() 方法来扩展验证器,添加自定义的验证规则。以下是如何创建一个名为 sumsTo 的自定义验证规则,用于验证多个字段之和是否等于特定值:

<?php

namespace App\Providers;

use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\Validator;
use Illuminate\Http\Request;

class AppServiceProvider extends ServiceProvider
{
    /**
     * Register any application services.
     *
     * @return void
     */
    public function register()
    {
        //
    }

    /**
     * Bootstrap any application services.
     *
     * @return void
     */
    public function boot(Request $request)
    {
        Validator::extend('sumsTo', function ($attribute, $value, $parameters) use ($request) {
            $expected = floatval(array_shift($parameters));
            $otherParameters = $request->only($parameters);
            return floatval(array_sum(array_merge(array_values($otherParameters), [ $value ]))) === $expected;
        });

        Validator::replacer('sumsTo', function ($message, $attribute, $rule, $parameters) {
            return str_replace(':expected', $parameters[0], $message);
        });
    }
}

这段代码需要在你的 AppServiceProvider 的 boot 方法中添加。sumsTo 验证规则接受三个参数:

  • $attribute: 当前正在验证的字段的名称。
  • $value: 当前正在验证的字段的值。
  • $parameters: 传递给验证规则的参数,第一个参数是期望的总和,后面的参数是要参与求和的其他字段的名称。

Validator::replacer用于自定义验证失败的提示信息。

使用自定义验证规则

在定义了自定义验证规则之后,就可以在表单验证中使用它了。以下是一个示例,演示如何验证三个字段 number1、number2 和 number3 的总和是否等于 100:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\Mynumber;
use Illuminate\Support\Facades\Validator;

class MyController extends Controller
{
    public function store(Request $request)
    {
        $validator = Validator::make($request->all(), [
            'number1' => 'required|numeric|sumsTo:100,number2,number3',
            'number2' => 'required|numeric|sumsTo:100,number1,number3',
            'number3' => 'required|numeric|sumsTo:100,number1,number2',
        ]);

        if ($validator->fails()) {
            return response()->json(['errors' => $validator->errors()], 422);
        }

        $data = $request->all();

        $myDb = new Mynumber();
        $myDb->number1 = $data['number1'];
        $myDb->number2 = $data['number2'];
        $myDb->number3 = $data['number3'];
        $myDb->save();

        return response()->json(['message' => 'Data saved successfully'], 201);
    }
}

在上面的代码中,sumsTo:100,number2,number3 表示 number1 字段的值加上 number2 和 number3 字段的值,总和必须等于 100。同样,number2 和 number3 也使用相同的验证规则,以确保所有字段都参与验证。

自定义错误消息

为了提供更友好的用户体验,可以自定义验证失败时的错误消息。在 resources/lang/zh_CN/validation.php 文件(如果没有就新建)中添加以下内容:

<?php

return [
    'sums_to' => '字段 :attribute 的值加上其他相关字段的值,总和必须等于 :expected。',
];

或者,你也可以在AppServiceProvider中自定义错误消息:

Validator::extend('sumsTo', function ($attribute, $value, $parameters) use ($request) {
    $expected = floatval(array_shift($parameters));
    $otherParameters = $request->only($parameters);
    return floatval(array_sum(array_merge(array_values($otherParameters), [ $value ]))) === $expected;
});

Validator::replacer('sumsTo', function ($message, $attribute, $rule, $parameters) {
    return str_replace(':expected', $parameters[0], $message);
});

然后在验证规则中使用:

$validator = Validator::make($request->all(), [
    'number1' => 'required|numeric|sumsTo:100,number2,number3',
    'number2' => 'required|numeric|sumsTo:100,number1,number3',
    'number3' => 'required|numeric|sumsTo:100,number1,number2',
],
[
    'sumsTo' => '字段 :attribute 的值加上其他相关字段的值,总和必须等于 :expected。',
]);

注意事项

  • 确保所有参与求和的字段都是数值类型,否则可能会导致验证失败。
  • 可以根据实际需求修改验证规则中的参数,例如,可以修改期望的总和值,或者添加更多的字段参与求和。
  • 为了提高代码的可读性,可以将自定义验证规则封装成一个独立的类。

总结

通过自定义验证规则,可以方便地在 Laravel 中验证多个数值输入字段的总和是否等于特定值。这种方法不仅可以用于验证百分比之和,还可以应用于其他需要验证多个字段之间关系的场景。掌握这种技巧可以帮助开发者编写更健壮、更可靠的应用程序。

终于介绍完啦!小伙伴们,这篇关于《Laravel多数值求和验证方法》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

稻壳阅读器官网入口及文档链接稻壳阅读器官网入口及文档链接
上一篇
稻壳阅读器官网入口及文档链接
KaLM-Embedding解析:腾讯文本模型深度解读
下一篇
KaLM-Embedding解析:腾讯文本模型深度解读
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3179次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    3390次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    3419次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    4525次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    3798次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码