marcinjean/minisnowflake 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

marcinjean/minisnowflake

最新稳定版本:1.1

Composer 安装命令:

composer require marcinjean/minisnowflake

包简介

A lightweight, case-insensitive, short ID generator using a mini Snowflake algorithm.

README 文档

README

License

A lightweight, case-insensitive, 9-character unique ID generator based on a mini Snowflake algorithm, written in PHP.

Built for high-performance systems needing short, collision-resistant IDs without long UUIDs.

Features

  • ✅ 9-character alphanumeric IDs
  • ✅ Based on a customizable epoch (like Twitter Snowflake)
  • ✅ No collision up to 256 IDs per millisecond
  • ✅ Case-insensitive for user input
  • ✅ Optional CLI tool for generating IDs
  • ✅ Fully unit-tested with PHPUnit
  • ✅ PSR-4 autoloaded, Composer ready

Installation

Install via Composer:

composer require marcinjean/minisnowflake

Basic Usage

use MarcinJean\MiniSnowflake\MiniSnowflake;

// Generate a new ID
$id = MiniSnowflake::generateId();

echo $id; // Example: "00D2D87XE"

// Validate an ID
if (MiniSnowflake::isValidId($id)) {
    echo "ID is valid!";
}

// Decode an ID
$data = MiniSnowflake::decodeId($id);

print_r($data);
/*
Array
(
    [timestamp] => 1714256780000
    [datetime] => 2025-04-27 22:19:40
    [sequence] => 123
)
*/

Custom Epoch

By default, IDs are generated relative to January 1st, 2025.

You can customize the epoch globally:

// Set a custom epoch (in milliseconds)
MiniSnowflake::setEpoch(strtotime('2024-01-01 00:00:00') * 1000);

// Reset to default epoch (2025-01-01)
MiniSnowflake::resetEpoch();

Or pass a custom epoch per call:

$customEpoch = strtotime('2023-01-01 00:00:00') * 1000;

$id = MiniSnowflake::generateId($customEpoch);
$data = MiniSnowflake::decodeId($id, $customEpoch);

CLI Usage

After installing:

php bin/generate-id.php

Example output:

Generated ID: 00D2D87XE
Decoded Info:
- Timestamp: 1714256780000
- Datetime: 2025-04-27 22:19:40
- Sequence: 123

You can also specify a custom epoch:

php bin/generate-id.php --epoch=1704067200000

Running Tests

This package is fully unit-tested with PHPUnit.

Install dev dependencies:

composer install

Run tests:

composer test

You should see:

OK (4 tests, 10 assertions)

License

This package is open-sourced software licensed under the MIT license.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-27