承接 azi/validator 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

azi/validator

最新稳定版本:2.0

Composer 安装命令:

composer require azi/validator

包简介

Server side user input validation library

README 文档

README

PHP Server Side Form Validation

Build Status Codacy Badge Latest Stable Version Total Downloads Latest Unstable Version License Join the chat at https://gitter.im/azeemhassni/validator

This is a small PHP package that makes it easy to validate forms in your project specially larger forms.

Installation Guide:

You can install Validator either via package download from github or via composer install. I encourage you to do the latter:

{ 
  "require": {
    "azi/validator": "2.*"
  }
} 

##Usage to get started

  • require composer autoloader
require 'vendor/autoload.php';
  • Instantiate the Validator class
use azi\Validator;
$v = new Validator();
  • Define Rules for each form field
  $rules = array(
        'name' => 'alpha|required',
        'age'  => 'num|required',
    );
  • Run the validator
$v->validate( $_POST, $rules );
  • check validator for errors, if validation fails redirect back to the form
if ( !$v->passed() ) {
        $v->goBackWithErrors();
    }
  • show validation errors to user
 <label>Name :
      <input type="text" name="name">
 </label>
 <?=  Validator::error('name'); ?>

you can wrap error messages with custom HTML markup

  Validator::error('confirm_password', '<span class="error">:message</span>');

Rules

  • required
  • num
  • alpha
  • alnum
  • email
  • ip
  • url
  • min:number
  • max:number
  • same:field_name

Custom Expressions & Messages

  • Custom Expressions

you can register your custom RegExp before running the validator

$v->registerExpression( 'cnic', '#^([0-9]{13})$#', 'Invalid CNIC number' );

registerExpression method takes 3 arguments

  • expressionID - unique name for the expression
  • pattern - the RegExp string
  • message [optional] - the error message to be retured if the validation fails
Validator::registerExpression($expressionID , $pattern, $message)
  • Custom Messages

you can also pass a custom error message with each rule

 $rules['full_name'] = "required--Please Enter your name";

Registring custom rules

this weekend (15th Aug 2015) i was working on a must have feature in validator which is accepting custom rules at run time. here is how you can do it from now on.

$validator = new azi\validator();
$validator->addRule('isUnique', function($field, $value){
    $query = mysqli_query("SELECT * FROM users WHERE username = $value");
    if($query->affected_rows > 0) {
        return "Username '$value' already exists please try something else";
    }
    
    return true;
);

now you can use this newly registered rule.

$validator->validate(
    $_POST, ['username' => 'isUnique|required']
);

now you have so much power on your fields validation do whatever you want in Closure you passed to Validator::addRule() as 2nd argument.

Conditional Rules

you can spacify conditional rules for a field

 $rules['age'] = 'if:gender[Male](required|min:2|num)';

Comparison Rules

you can also compare a field with another

  $rules['password'] = 'required|min:8';
  $rules['confirm_password'] = 'same:password';

统计信息

  • 总下载量: 189
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 21
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 19
  • Watchers: 4
  • Forks: 9
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-03-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固