a-j-n/egyptian-national-id-laravel
最新稳定版本:v1.0.1
Composer 安装命令:
composer require a-j-n/egyptian-national-id-laravel
包简介
Egyptian National ID validation, parsing, and generation package for PHP and Laravel.
README 文档
README
PHP and Laravel package for Egyptian National ID:
- validation
- parsing
- generation
- sanitization (including Arabic numerals)
Credits
This package is a PHP/Laravel adaptation of the original project by Mahmoud Ebeid (mahmoudEbeid2):
https://github.com/mahmoudEbeid2/egyptian-national-id
Installation
composer require a-j-n/egyptian-national-id-laravel
Laravel package discovery is enabled automatically.
Laravel Setup
For Laravel 10/11/12, no manual setup is needed after install.
The package uses Laravel auto-discovery via composer.json (extra.laravel.providers and extra.laravel.aliases).
To verify discovery in Laravel 12:
php artisan package:discover
Then test quickly in Tinker:
php artisan tinker
app(EgyptianNationalId\NationalIdService::class)->validate('30001010123456');
If you need manual registration, add:
// config/app.php 'providers' => [ EgyptianNationalId\EgyptianNationalIdServiceProvider::class, ], 'aliases' => [ 'NationalId' => EgyptianNationalId\Facades\NationalId::class, ],
Quick Usage
use EgyptianNationalId\NationalIdService; $service = app(NationalIdService::class); $isValid = $service->validate('30001010123456'); $id = $service->generate(['gender' => 'Male']); $parsed = $service->parse($id);
Facade Usage
use EgyptianNationalId\Facades\NationalId; $isValid = NationalId::validate('30001010123456'); $parsed = NationalId::parse('30001010123456');
Validation Rule (String)
$request->validate([ 'national_id' => ['required', 'national_id'], ]);
Validation Rule (Class)
use EgyptianNationalId\Rules\NationalIdRule; $request->validate([ 'national_id' => ['required', new NationalIdRule()], ]);
Parse Result Shape
[ 'national_id' => '...', 'birth_date' => DateTimeImmutable, 'birth_year' => 1998, 'birth_month' => 7, 'birth_day' => 21, 'age' => 27, 'gender' => 'Male'|'Female', 'governorate' => ['code' => 1, 'name_en' => 'Cairo', 'name_ar' => 'Al Qahirah', 'region' => 'Cairo'], 'region' => 'Cairo', 'inside_egypt' => true, 'is_adult' => true ]
API
sanitize(string|int|null $id): stringvalidate(string|int|null $id): boolparse(string|int|null $id): arrayextractBirthDate(string|int|null $id): DateTimeImmutableextractGender(string|int|null $id): stringextractGovernorate(string|int|null $id): ?arraycalculateAge(DateTimeInterface $birthDate, ?DateTimeInterface $at = null): intgenerate(array $options = []): string
Generate Options
birth_year(int)birth_month(int)birth_day(int)governorate_code(int)gender(MaleorFemale)
License
MIT
统计信息
- 总下载量: 2
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 7
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-03