Posted in PHP onSeptember 20, 2020
当代框架基本都是有组件构成,这使得框架变得更加灵活。The Laravel Components | github Laravel 中有不少优质组件,那如何在 Laravel 之外使用 illuminate 组件呢?
illuminate/validation
以 illuminate/validation 为例,validation 有丰富的数据验证功能。
在项目的 composer.json 文件中添加:
... "require": { ... "illuminate/validation": "^5.8", ...
从 Laravel-Lang/lang 项目中复制需要的语言文件放到自己的项目中。
例如:在 Yii2 项目中,复制对应语言文件到项目中的 assets/lang/zh-CN/validation.php。
创建 common/Validator.php:
namespace app\common; use Illuminate\Filesystem\Filesystem; use Illuminate\Translation\FileLoader; use Illuminate\Translation\Translator; use Illuminate\Validation\Factory; class Validator { private static $instance = null; private function __construct() { } public static function getInstance(): Factory { if (null === static::$instance) { $translationPath = get_alias('@assets/lang'); $translationLocale = 'zh-CN'; $transFileLoader = new FileLoader(new Filesystem(), $translationPath); $translator = new Translator($transFileLoader, $translationLocale); static::$instance = new Factory($translator); } return static::$instance; } }
在全局函数文件添加:
// https://learnku.com/docs/laravel/5.8/validation/3899#manually-creating-validators // $rules = [ // 'name' => 'required|string|min:2|max:5', // 'code' => 'required|string|min:2|max:5', // ]; function validator(array $data, array $rules, array $messages = [], array $customAttributes = []) { return \app\common\Validator::getInstance()->make($data, $rules, $messages, $customAttributes); }
测试使用:
$rules = ['name' => 'required|numeric']; $customAttributes = ['name' => 'My name']; $messages = ['name.required' => 'A name is required',]; $validator = validator($data, $rules, $customAttributes, $messages); if ($validator->fails()) { $errors = $validator->errors()->all(); Response::error(Errors::ParamsInvalid, implode(',', $errors), $errors); }
总结
到此这篇关于如何在Laravel之外使用illuminate组件的文章就介绍到这了,更多相关Laravel之外使用illuminate组件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!
如何在Laravel之外使用illuminate组件详解
- Author -
daisy声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@