定制 blamodex/laravel-otp 二次开发

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

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

blamodex/laravel-otp

最新稳定版本:v1.0.0

Composer 安装命令:

composer require blamodex/laravel-otp

包简介

A simple, Laravel-ready one-time password (OTP) package for rapid prototyping and lightweight use cases.

README 文档

README

Latest Version on Packagist GitHub Tests Action Status Total Downloads License Laravel PHP

A lightweight Laravel package to add one-time password (OTP) capabilities to any Eloquent model using polymorphic relationships.

Table of Contents

🚀 Features

  • Attach OTP functionality to any model using a trait
  • Polymorphic support for multiple model types
  • Configurable alphabet, length, expiry, and hash algorithm
  • Secure hashing via password_hash and password_verify
  • Auto-expiration and one-time use enforcement
  • Clean architecture: trait, model, service, generator

📦 Installation

Install the package with Composer:

composer require blamodex/laravel-otp

Publish the config file:

php artisan vendor:publish --tag=blamodex-otp-config

Run the migrations:

php artisan migrate

⚙️ Configuration

Configuration lives in config/otp.php:

return [
    /* PASSWORD ALGORITHM, SEE https://www.php.net/manual/en/function.password-hash.php FOR MORE INFO */
    'algorithm' => PASSWORD_BCRYPT,

    /* PASSWORD ALPHABET */

    //NUMBERS ONLY ALPHABET
    'alphabet' => '0123456789',

    //"WORD SAFE" ALPHABET
    //'alphabet' => '256789BCDFGHJKMNPQRSTVXW',

    //ALPHANUM ALPHABET
    //'alphabet' => '0123456789ABCDEFGHIJKLMNOPQRSTUV';

    /* PASSWORD LENGTH */
    'length' => 6,

    /* PASSWORD EXPIRY */
    'expiry' => 600
];

🧩 Usage

1. Implement the interface and use the trait

use Blamodex\Otp\Traits\OneTimePasswordable;
use Blamodex\Otp\Contracts\OneTimePasswordableInterface;

class User extends Model implements OneTimePasswordableInterface
{
    use OneTimePasswordable;
}

2. Generate an OTP

$user = User::find(1);
$otp = $user->generateOtp(); // returns raw password

3. Verify an OTP

if ($user->verifyOtp('123456')) {
    // Success
} else {
    // Failure
}

🧪 Testing

This package uses Orchestra Testbench and PHPUnit.

Run tests:

composer test

Check code style:

composer lint

Check code style and fix:

composer lint:fix

Check coverage (with Xdebug):

composer test:coverage

📁 Project Structure

src/
├── Models/
│   └── OneTimePassword.php
├── Data/
│   └── OtpData.php
├── Services/
│   ├── OtpGenerator.php
│   └── OtpService.php
├── Traits/
│   └── OneTimePasswordable.php
├── Contracts/
│   └── OneTimePasswordableInterface.php
├── config/
│   └── otp.php
└── database/
    └── migrations/
        └── 202x_xx_xx_create_one_time_passwords_table.php

tests/
├── Unit/
├── Fixtures/
└── TestCase.php

🤝 Contributing

We welcome contributions! Please see CONTRIBUTING.md for details.

📝 Changelog

Please see CHANGELOG.md for recent changes.

📄 License

MIT © Blamodex

For more information, see the LICENSE file.

🔗 Links

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-29