qdenka/easyvalidation
最新稳定版本:1.0
Composer 安装命令:
composer require qdenka/easyvalidation
包简介
EasyValidation — a package for simple, fast, and extendable data validation (email, URL, number, date, credit card, IP, phone, etc.).
README 文档
README
EasyValidation is a lightweight PHP library for validating common data types. Built with DDD, SOLID, and DRY principles, it offers both a factory-based API and convenient static helper methods.
📋 Table of Contents
✨ Features
- ✅ Validate emails (standard, Gmail-only, disposable)
- ✅ Validate URLs, numbers, dates
- ✅ Validate IPs (IPv4 & IPv6)
- ✅ Validate UUIDs (v1–v5)
- ✅ Validate JSON and Base64 strings
- ✅ Validate international phone numbers (E.164)
- 📦 PSR-4 autoloading
- 🔄 Factory-based API + static helpers
- ⚙️ Easily extendable with new validators
⚙️ Requirements
- PHP ^7.4 || ^8.0
🚀 Installation
Install with Composer:
composer require qdenka/easyvalidation
Autoloading is configured via PSR-4 (QDenka\EasyValidation\).
🛠️ Usage
Factory API
Use ValidatorFactory to retrieve any validator by its type key:
use QDenka\EasyValidation\Application\Validators\ValidatorFactory; \$types = ['email','google_email','disposable_email','url','number','date','ip','uuid','json','base64','phone']; foreach (\$types as \$type) { \$validator = ValidatorFactory::create(\$type); \$value = 'test_value_for_' . \$type; if (\$validator && \$validator->validate(\$value)) { echo "[\$type] valid\n"; } else { echo "[\$type] invalid\n"; } }
Static Helpers
For quick checks, use the Validator facade:
use QDenka\EasyValidation\Infrastructure\Factories\Validator; if (Validator::isValidEmail('user@example.com')) { echo "Valid email"; } if (Validator::isGoogleMail('user@gmail.com')) { echo "It's a Gmail address"; } if (!Validator::isDisposableEmail('temp@mailinator.com')) { echo "Disposable email detected"; } // Other helpers: Validator::isValidUrl('https://example.com'); Validator::isValidNumber('123.45'); Validator::isValidDate('2023-04-23'); Validator::isValidIp('2001:db8::1'); Validator::isValidUuid('550e8400-e29b-41d4-a716-446655440000'); Validator::isValidJson('{"foo":1}'); Validator::isValidBase64(base64_encode('hello')); Validator::isValidPhone('+1234567890');
📑 Available Validators
| Type | Static Helper | Description |
|---|---|---|
email |
isValidEmail() |
RFC-compliant email |
google_email |
isGoogleMail() |
Gmail & Googlemail domains |
disposable_email |
!isDisposableEmail() |
Blacklisted disposable domains |
url |
isValidUrl() |
HTTP/HTTPS URLs |
number |
isValidNumber() |
Numeric values |
date |
isValidDate() |
Date in Y-m-d (configurable format) |
ip |
isValidIp() |
IPv4 & IPv6 addresses |
uuid |
isValidUuid() |
UUID v1–v5 |
json |
isValidJson() |
JSON string parsing |
base64 |
isValidBase64() |
Base64-encoded data |
phone |
isValidPhone() |
International E.164 phone numbers |
⚙️ Configuration
Disposable Domains List
Customize disposable email domains by editing config/disposable_domains.php:
return [ 'mailinator.com', '10minutemail.com', // add your domains here ];
Ensure all domains are lowercase.
🧩 Extending
To add a new validator:
- Implement
ValidatorInterfaceinsrc/Domain/YourType/YourValidator.php. - Add your class to
VALIDATOR_MAPinsrc/Infrastructure/Factories/Validator.php. - (Optional) Add a static helper in the same class.
- Write tests under
tests/following existing patterns.
🧪 Testing
Run PHPUnit:
vendor/bin/phpunit --colors
All tests must pass before merging.
🤝 Contributing
- Fork repository
- Create a feature branch (
git checkout -b feature/NewValidator) - Commit changes (
git commit -m 'Add NewValidator') - Push (
git push origin feature/NewValidator) - Open a Pull Request
Follow PSR-12 coding standards and include tests.
📄 License
This project is licensed under the MIT License. See LICENSE for details.
统计信息
- 总下载量: 1
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 3
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-04-23