脱离laravel框架使用illuminate下的组件

Illuminate下面有很多分离自Laravel的控件。或许你很抵抗使用Laravel , 但是你没有理由不喜欢使用Illuminate,组件的使用方法可以查看Laravel的文档 

github地址:https://github.com/illuminate

 

独立使用Illuminate/Validation验证器

{
  "require": {
    "illuminate/validation": "^5.8"
  }
}

打开resource/lang/cn/validation.php

<?php

return [

/*
|--------------------------------------------------------------------------
| Validation Language Lines
|--------------------------------------------------------------------------
|
| The following language lines contain the default error messages used by
| the validator class. Some of these rules have multiple versions such
| as the size rules. Feel free to tweak each of these messages here.
|
*/

'accepted'             => ':attribute 必须接受',
'active_url'           => ':attribute 必须是一个合法的 URL',
'after'                => ':attribute 必须是 :date 之后的一个日期',
'after_or_equal'       => ':attribute 必须是 :date 之后或相同的一个日期',
'alpha'                => ':attribute 只能包含字母',
'alpha_dash'           => ':attribute 只能包含字母、数字、中划线或下划线',
'alpha_num'            => ':attribute 只能包含字母和数字',
'array'                => ':attribute 必须是一个数组',
'before'               => ':attribute 必须是 :date 之前的一个日期',
'before_or_equal'      => ':attribute 必须是 :date 之前或相同的一个日期',
'between'              => [
    'numeric' => ':attribute 必须在 :min 到 :max 之间',
    'file'    => ':attribute 必须在 :min 到 :max KB 之间',
    'string'  => ':attribute 必须在 :min 到 :max 个字符之间',
    'array'   => ':attribute 必须在 :min 到 :max 项之间',
],
'boolean'              => ':attribute 字符必须是 true 或 false',
'confirmed'            => ':attribute 二次确认不匹配',
'date'                 => ':attribute 必须是一个合法的日期',
'date_format'          => ':attribute 与给定的格式 :format 不符合',
'different'            => ':attribute 必须不同于 :other',
'digits'               => ':attribute 必须是 :digits 位.',
'digits_between'       => ':attribute 必须在 :min 和 :max 位之间',
'dimensions'           => ':attribute 具有无效的图片尺寸',
'distinct'             => ':attribute 字段具有重复值',
'email'                => ':attribute 必须是一个合法的电子邮件地址',
'exists'               => '选定的 :attribute 是无效的.',
'file'                 => ':attribute 必须是一个文件',
'filled'               => ':attribute 的字段是必填的',
'image'                => ':attribute 必须是 jpeg, png, bmp 或者 gif 格式的图片',
'in'                   => '选定的 :attribute 是无效的',
'in_array'             => ':attribute 字段不存在于 :other',
'integer'              => ':attribute 必须是个整数',
'ip'                   => ':attribute 必须是一个合法的 IP 地址。',
'json'                 => ':attribute 必须是一个合法的 JSON 字符串',
'max'                  => [
    'numeric' => ':attribute 的最大长度为 :max 位',
    'file'    => ':attribute 的最大为 :max',
    'string'  => ':attribute 的最大长度为 :max 字符',
    'array'   => ':attribute 的最大个数为 :max 个.',
],
'mimes'                => ':attribute 的文件类型必须是 :values',
'min'                  => [
    'numeric' => ':attribute 的最小长度为 :min 位',
    'file'    => ':attribute 大小至少为 :min KB',
    'string'  => ':attribute 的最小长度为 :min 字符',
    'array'   => ':attribute 至少有 :min 项',
],
'not_in'               => '选定的 :attribute 是无效的',
'numeric'              => ':attribute 必须是数字',
'present'              => ':attribute 字段必须存在',
'regex'                => ':attribute 格式是无效的',
'required'             => ':attribute 字段是必须的',
'required_if'          => ':attribute 字段是必须的当 :other 是 :value',
'required_unless'      => ':attribute 字段是必须的,除非 :other 是在 :values 中',
'required_with'        => ':attribute 字段是必须的当 :values 是存在的',
'required_with_all'    => ':attribute 字段是必须的当 :values 是存在的',
'required_without'     => ':attribute 字段是必须的当 :values 是不存在的',
'required_without_all' => ':attribute 字段是必须的当 没有一个 :values 是存在的',
'same'                 => ':attribute 和 :other 必须匹配',
'size'                 => [
    'numeric' => ':attribute 必须是 :size 位',
    'file'    => ':attribute 必须是 :size KB',
    'string'  => ':attribute 必须是 :size 个字符',
    'array'   => ':attribute 必须包括 :size 项',
],
'string'               => ':attribute 必须是一个字符串',
'timezone'             => ':attribute 必须是个有效的时区.',
'unique'               => ':attribute 已存在',
'url'                  => ':attribute 无效的格式',

/*
|--------------------------------------------------------------------------
| Custom Validation Language Lines
|--------------------------------------------------------------------------
|
| Here you may specify custom validation messages for attributes using the
| convention "attribute.rule" to name the lines. This makes it quick to
| specify a specific custom language line for a given attribute rule.
|
*/

'custom' => [
    'attribute-name' => [
        'rule-name' => 'custom-message',
    ],
],

/*
|--------------------------------------------------------------------------
| Custom Validation Attributes
|--------------------------------------------------------------------------
|
| The following language lines are used to swap attribute place-holders
| with something more reader friendly such as E-Mail Address instead
| of "email". This simply helps us make messages a little cleaner.
|
*/

'attributes' => [
   // 'name'         => '名字',
   // 'age'         => '年龄',
],

];

将vendor引入,自定义类。

<?php

namespace Rester;

use Illuminate\Validation\Factory;
use Illuminate\Translation\FileLoader;
use Illuminate\Translation\Translator;
use Illuminate\Filesystem\Filesystem;

class Validator extends Factory
{
    private static $message = 'OK';
    private static $headers = [
        'empty'   => '验证规则或验证数据为空',
        'neq_arr' => '验证规则或验证数据不是数组'
    ];

    /***
     * 创建实例
     *
     * @return \Illuminate\Validation\Factory
     */
    public static function getInstance()
    {
        static $validator = null;
        if ($validator === null) {
            $translationPath = __DIR__.'/lang';
            $translationLocale = 'en';
            $transFileLoader = new FileLoader(new Filesystem, $translationPath);
            $translator = new Translator($transFileLoader, $translationLocale);
            $validator = new Factory($translator);
        }
        return $validator;
    }

    /**
     * @param array $data
     * @param array $rules    验证规则
     * @param array $messages 验证数据
     * @param array $customAttributes
     * @return bool
     */
    public static function validators(array $data, array $rules, array $messages = [], array $customAttributes = [])
    {
        if (empty($rules) || empty($data)) {
            self::$message = self::$headers['empty'];
            return false;
        }
        if (is_array($rules) && is_array($data)) {
            $v = self::vmake($rules, $data, $messages, $customAttributes);
            if ($v->fails()) {
                self::$message = $v->messages();
                return false;
            }
            return true;
        }
        self::$message = self::$headers['neq_arr'];
        return false;
    }

    /**
     * 验证实例
     *
     * @param array $data
     * @param array $rules
     * @param array $messages
     * @param array $customAttributes
     * @return \Illuminate\Validation\Validator
     */
    private static function vmake(array $data, array $rules, array $messages = [], array $customAttributes = [])
    {
        $v = self::getInstance()->make($data, $rules, $messages, $customAttributes);
        return $v;
    }

    /**
     * 获取错误消息
     *
     * @return string
     */
    public static function getMessage()
    {
        return self::$message;
    }
}

 在项目中引入自定义类,调用验证

//验证数据
$data = [
    'name' => '1'
];
//验证规则
$rules = [
    'name' => 'required|string|min:2|max:5',
];
$customAttributes = [
    'name' => '姓名',
];
if (Rester\Validator::validators($rules, $data, [], $customAttributes)) {
    echo 'ok';
} else {
    echo Rester\Validator::getMessage();
}

独立使用Illuminate/Database

如果要监听 SQL ,还需要添加 illuminate/Events

"require": {
    ...
    "illuminate/database": "5.8.*",
    "illuminate/Events": "5.8.*",
    ...
  },

引入

use Illuminate\Database\Capsule\Manager as Capsule;

$capsule = new Capsule;

$capsule->addConnection([
    'driver'    => 'mysql',
    'host'      => 'localhost',
    'database'  => 'database',
    'username'  => 'root',
    'password'  => 'password',
    'charset'   => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix'    => '',
]);

// Set the event dispatcher used by Eloquent models... (optional)
use Illuminate\Events\Dispatcher;
use Illuminate\Container\Container;
$capsule->setEventDispatcher(new Dispatcher(new Container));

// 设置全局静态可访问DB
$capsule->setAsGlobal();

// 启动Eloquent (如果只使用查询构造器,这个可以注释)
$capsule->bootEloquent();  
Using The Eloquent ORM
class User extends Illuminate\Database\Eloquent\Model {}
$users = User::where('votes', '>', 1)->get();
Using The Query Builder
 
use Illuminate\Database\Capsule\Manager as DB;
$users = DB::table('users')->where('votes', '>', 100)->get();
Using The Schema Builder
DB::schema()->create('users', function ($table) {
    $table->increments('id');
    $table->string('email')->unique();
    $table->timestamps();
});
 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值