medo19/otp-shield
最新稳定版本:v1.0.6
Composer 安装命令:
composer require medo19/otp-shield
包简介
A Laravel plug-n-play OTP/TOTP package
README 文档
README
OTPSHIELD is a professional, plug-n-play OTP/TOTP package for Laravel. It provides secure, time-based OTPs with:
- Polymorphic OTP storage (supports users, admins, devices, etc.)
- Encrypted secrets
- Middleware for route protection
- SVG QR code generation for Google Authenticator, Authy, etc.
- Artisan commands for management
- Configurable period, digits, and lockout policies
📦 Installation
Require the package and dependencies via Composer:
composer require medo19/otp-shield
Add OTPSHIELD to your Laravel project (if not using auto-discovery):
// config/app.php 'providers' => [ ... OtpShield\OtpShieldServiceProvider::class, ], 'aliases' => [ ... 'OtpShield' => OtpShield\Facades\OtpShield::class, ],
Publish the configuration and migrations:
php artisan vendor:publish --provider="OtpShield\OtpShieldServiceProvider" --tag="config" php artisan migrate
⚙️ Configuration
config/otp-shield.php contains:
return [ 'digits' => 6, // Number of OTP digits 'period' => 30, // Validity period in seconds 'algorithm' => 'sha1', // Hash algorithm 'issuer' => env('APP_NAME', 'Laravel App'), 'max_attempts' => 5, // Max failed attempts before lockout 'lockout_time' => 300, // Lockout duration in seconds 'default_otp_type' => 'totp', // allowed totp & hotp - Default : totp ];
🧩 Usage in Models
Add the trait and contract to your User model:
use OtpShield\Traits\HasOtp; use OtpShield\Contracts\OtpAuthenticatable; class User extends Authenticatable implements OtpAuthenticatable { use HasOtp; }
🔑 Enable OTP
$otp = $user->enableOtp();
🖼 Generate QR Code (SVG)
$qrSvg = $user->getOtpQrCode(); // returns SVG string // Embed in Blade echo '<div class="otp-qr">'.$qrSvg.'</div>';
Or via the facade directly:
use OtpShield\Facades\OtpShield; $qrSvg = OtpShield::provisioningQr($secret, $user->email, config('otp-shield.issuer'));
✅ Verify OTP
$isValid = $user->verifyOtp('123456'); // true/false
🛡 Middleware Protection
Route::middleware(['auth', \OtpShield\Middleware\EnsureOtpVerified::class]) ->group(function () { Route::get('/secure-data', [SecureDataController::class, 'index']); });
🛠 Artisan Commands
- Enable OTP:
php artisan otp-shield:enable {user_id}
- Disable OTP:
php artisan otp-shield:disable {user_id}
- Verify OTP manually:
php artisan otp-shield:verify {user_id} {code}
- Generate QR code for API / frontend (SVG):
php artisan otp-shield:generate-qr {user_id} --file=optional.png
💡 Best Practices
- Always encrypt secrets — OTPSHIELD handles this automatically.
- Use middleware to protect sensitive routes.
- Return QR as SVG in APIs for dynamic frontend rendering.
- Monitor failed attempts to prevent brute-force attacks.
🧪 Example Workflow
// 1. Enable OTP $otp = $user->enableOtp(); // 2. Generate QR code for frontend $qrSvg = $user->getOtpQrCode(); // 3. Display QR code for scanning in app echo $qrSvg; // 4. User scans QR in Google Authenticator // 5. Verify OTP code during login $isValid = $user->verifyOtp($inputOtp); if ($isValid) { // Grant access }
🌐 Supported Apps
- Google Authenticator
- Authy
- Microsoft Authenticator
- Any TOTP-compatible app
⚡ Summary
OTPSHIELD makes adding secure, TOTP-based authentication to Laravel fast and reliable, with minimal setup, modern SVG QR codes, and robust security features.
统计信息
- 总下载量: 20
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-09-04