您好,登錄后才能下訂單哦!
在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組件的方法問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。