| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- <?php
- // +----------------------------------------------------------------------
- // | likeshop100%开源免费商用商城系统
- // +----------------------------------------------------------------------
- // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
- // | 开源版本可自由商用,可去除界面版权logo
- // | 商业版本务必购买商业授权,以免引起法律纠纷
- // | 禁止对系统程序代码以任何目的,任何形式的再发布
- // | gitee下载:https://gitee.com/likeshop_gitee
- // | github下载:https://github.com/likeshop-github
- // | 访问官网:https://www.likeshop.cn
- // | 访问社区:https://home.likeshop.cn
- // | 访问手册:http://doc.likeshop.cn
- // | 微信公众号:likeshop技术社区
- // | likeshop团队 版权所有 拥有最终解释权
- // +----------------------------------------------------------------------
- // | author: likeshopTeam
- // +----------------------------------------------------------------------
- namespace app\adminapi\validate\goods;
- class GoodsSpecPriceImport extends \think\Validate
- {
- protected $rule = [
- 'lists' => ['require', 'checkLists'],
- ];
- protected $message = [
- 'lists.require' => '上传文件不能为空',
- ];
- function checkLists($lists, $rule, $data)
- {
- $nums = count($lists) - 1;
- if ($nums < 1) {
- return '导入的文件商品规格价格信息为空';
- }
- if ($nums > 2000) {
- return '单次最多导入2000条商品规格价格信息';
- }
- foreach ($lists as $key => $info) {
- // 跳过表头
- if ($key == 1) {
- continue;
- }
- // 检查必填字段:商品ID(A列)和规格ID(D列)
- if (empty(trim($info['A'])) || empty(trim($info['D']))) {
- return '商品规格价格信息:第' . ($key) . '行存在未填写的商品ID或规格ID';
- }
- // 验证商品ID是否为数字
- if (!is_numeric(trim($info['A']))) {
- return '商品规格价格信息:第' . ($key) . '行商品ID必须为数字';
- }
- // 验证规格ID是否为数字
- if (!is_numeric(trim($info['D']))) {
- return '商品规格价格信息:第' . ($key) . '行规格ID必须为数字';
- }
- // 验证销售价格(F列)
- if (!empty(trim($info['F'])) && !is_numeric(trim($info['F']))) {
- return '商品规格价格信息:第' . ($key) . '行销售价格必须为数字';
- }
- // 验证划线价格(G列)
- if (!empty(trim($info['G'])) && !is_numeric(trim($info['G']))) {
- return '商品规格价格信息:第' . ($key) . '行划线价格必须为数字';
- }
- // 验证成本价格(H列)
- if (!empty(trim($info['H'])) && !is_numeric(trim($info['H']))) {
- return '商品规格价格信息:第' . ($key) . '行成本价格必须为数字';
- }
- // 验证库存数量(I列)
- if (!empty(trim($info['I'])) && (!is_numeric(trim($info['I'])) || trim($info['I']) < 0)) {
- return '商品规格价格信息:第' . ($key) . '行库存数量必须为非负整数';
- }
- // 验证重量(J列)
- if (!empty(trim($info['J'])) && (!is_numeric(trim($info['J'])) || trim($info['J']) < 0)) {
- return '商品规格价格信息:第' . ($key) . '行重量必须为非负数';
- }
- // 验证体积(K列)
- if (!empty(trim($info['K'])) && (!is_numeric(trim($info['K'])) || trim($info['K']) < 0)) {
- return '商品规格价格信息:第' . ($key) . '行体积必须为非负数';
- }
- }
- return true;
- }
- }
|