定制 a-j-n/egyptian-national-id-laravel 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

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): string
  • validate(string|int|null $id): bool
  • parse(string|int|null $id): array
  • extractBirthDate(string|int|null $id): DateTimeImmutable
  • extractGender(string|int|null $id): string
  • extractGovernorate(string|int|null $id): ?array
  • calculateAge(DateTimeInterface $birthDate, ?DateTimeInterface $at = null): int
  • generate(array $options = []): string

Generate Options

  • birth_year (int)
  • birth_month (int)
  • birth_day (int)
  • governorate_code (int)
  • gender (Male or Female)

License

MIT

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固