PHPackages                             blackbear/validation - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Validation &amp; Sanitization](/categories/validation)
4. /
5. blackbear/validation

ActiveLibrary[Validation &amp; Sanitization](/categories/validation)

blackbear/validation
====================

validation data

1.0.0(8y ago)2545MITPHP

Since Feb 3Pushed 8y ago1 watchersCompare

[ Source](https://github.com/luongvancong/validation)[ Packagist](https://packagist.org/packages/blackbear/validation)[ RSS](/packages/blackbear-validation/feed)WikiDiscussions master Synced 3d ago

READMEChangelogDependencies (1)Versions (2)Used By (0)

Class Validation for php
========================

[](#class-validation-for-php)

Validator
=========

[](#validator)

Validate input value

Installation
============

[](#installation)

```
composer require blackbear/validation

```

Example
=======

[](#example)

```
$data = [
		'age' => 20,
		'email' => 'cong.itsoft@gmail.com'
	];
	$rules = [
		'age' => 'required',
		'email' => 'email|required'
	];
	$messages = [
		'age.required' => 'Please fill age',
		'email.email' => 'Please fill email'
	];

	$validator = new Validator($data, $rules, $messages);

if ($validator->passes()) {
  echo 'Validate successful';
} else {
  echo 'Validate fails'
}

```

Get error messages
==================

[](#get-error-messages)

```
$errors = $validator->getErrors();

```

Add custom rule
===============

[](#add-custom-rule)

```
	$validator->addExtension('bigger', function($attribue, $value) {
		return $value > $attribue[0];
	});

$data = [
		'age' => 20,
		'email' => 'cong.itsoft@gmail.com'
	];
	$rules = [
		'age' => 'required|bigger:18',
		'email' => 'email|required'
	];
	$messages = [
		'age.required' => 'Please fill age',
		'email.email' => 'Please fill email'
	];

$validator = new Validator();
$validator->setData($data)
			    ->setRules($rules)
	        ->setMessages($messages);

if ($validator->passes()) {
  echo 'Validate successful';
} else {
  echo 'Validate fails'
}

```

Public method
=============

[](#public-method)

`setData(array $data)`

`setRules(array $rules)`

`setMessages(array $messages)`

`passes()`

`fails()`

Default rules
=============

[](#default-rules)

`required`

`email`

`exception`

`ip`

`min`: min:20

`max`: max:20

`in_array`: in\_array:1,2,3

`not_in_array`: not\_in\_array:1,2,3

`between`: between:10,100

`regex`: regexp:/^(\[\\d\]+)$/

`url`

`int`

`float`

`double`

`boolean`

`nullable`

`equals`: equals:8

**[Unit test](https://github.com/luongvancong/validation/blob/master/tests/ValidatorTest.php)**

###  Health Score

29

—

LowBetter than 59% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity15

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity63

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

3023d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/2cd3cf3ae34d260cf01e9fa6768f6c49125edc17d8000586386c7115873a8f57?d=identicon)[luongvancong](/maintainers/luongvancong)

---

Top Contributors

[![luongvancong](https://avatars.githubusercontent.com/u/2561253?v=4)](https://github.com/luongvancong "luongvancong (22 commits)")

---

Tags

validation

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/blackbear-validation/health.svg)

```
[![Health](https://phpackages.com/badges/blackbear-validation/health.svg)](https://phpackages.com/packages/blackbear-validation)
```

###  Alternatives

[composer/semver

Version comparison library that offers utilities, version constraint parsing and validation.

3.3k489.6M672](/packages/composer-semver)[giggsey/libphonenumber-for-php

A library for parsing, formatting, storing and validating international phone numbers, a PHP Port of Google's libphonenumber.

5.0k148.7M416](/packages/giggsey-libphonenumber-for-php)[respect/validation

The most awesome validation engine ever created for PHP

5.9k37.4M383](/packages/respect-validation)[propaganistas/laravel-phone

Adds phone number functionality to Laravel based on Google's libphonenumber API.

3.0k35.7M107](/packages/propaganistas-laravel-phone)[opis/json-schema

Json Schema Validator for PHP

64236.9M186](/packages/opis-json-schema)[giggsey/libphonenumber-for-php-lite

A lite version of giggsey/libphonenumber-for-php, which is a PHP Port of Google's libphonenumber

8412.9M47](/packages/giggsey-libphonenumber-for-php-lite)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
