tempmailchecker/php-sdk
最新稳定版本:v1.0.0
Composer 安装命令:
composer require tempmailchecker/php-sdk
包简介
PHP SDK for TempMailChecker API - Detect disposable email addresses in real-time
README 文档
README
TempMailChecker PHP SDK
Detect disposable email addresses in real-time with the TempMailChecker API. Block fake signups, prevent spam, and protect your platform from abuse.
🚀 Quick Start
Installation
composer require tempmailchecker/php-sdk
Basic Usage
<?php require 'vendor/autoload.php'; use TempMailChecker\TempMailChecker; // Initialize with your API key $checker = new TempMailChecker('your_api_key_here'); // Check if an email is disposable if ($checker->isDisposable('user@tempmail.com')) { echo "Blocked: This is a disposable email"; } else { echo "Valid: This is a legitimate email"; }
📖 Documentation
Check Email Address
$checker = new TempMailChecker('your_api_key'); // Simple boolean check $isDisposable = $checker->isDisposable('test@10minutemail.com'); // Get full response $result = $checker->check('user@example.com'); // Returns: ['temp' => false]
Check Domain
// Check just the domain $isDisposable = $checker->isDisposableDomain('tempmail.com'); // Get full response $result = $checker->checkDomain('guerrillamail.com');
Regional Endpoints
Use regional endpoints for lower latency. All endpoints use /check and /usage directly (no /api prefix):
use TempMailChecker\TempMailChecker; // EU endpoint (default) $checker = new TempMailChecker('your_api_key'); // or explicitly: $checker = new TempMailChecker('your_api_key', TempMailChecker::ENDPOINT_EU); // US endpoint $checker = new TempMailChecker('your_api_key', TempMailChecker::ENDPOINT_US); // Asia endpoint $checker = new TempMailChecker('your_api_key', TempMailChecker::ENDPOINT_ASIA);
Check Usage
$usage = $checker->getUsage(); // Returns: ['usage_today' => 15, 'limit' => 25, 'reset' => 'midnight UTC']
Error Handling
use TempMailChecker\TempMailChecker; use Exception; try { $isDisposable = $checker->isDisposable('user@example.com'); } catch (Exception $e) { if (strpos($e->getMessage(), 'Rate limit') !== false) { // Handle rate limit } else { // Handle other errors echo "Error: " . $e->getMessage(); } }
🎯 Use Cases
- Block Fake Signups: Stop disposable emails at registration
- Prevent Promo Abuse: Protect referral programs and coupons
- Clean Email Lists: Remove throwaway addresses from newsletters
- Reduce Spam: Filter out disposable emails in contact forms
- Protect Communities: Ensure real users in forums and chat
⚡ Features
- ✅ Simple API: One method call, one boolean response
- ✅ Fast: Sub-millisecond processing, ~70ms real-world latency
- ✅ Massive Database: 277,000+ disposable email domains
- ✅ Auto-Updates: Database updated daily automatically
- ✅ Regional Endpoints: US, EU, and Asia for optimal performance
- ✅ Free Tier: 25 requests/day, no credit card required
🔑 Get Your API Key
- Sign up at tempmailchecker.com
- Get 25 free requests per day
- Start blocking disposable emails immediately
📚 Examples
Laravel Integration
namespace App\Services; use TempMailChecker\TempMailChecker; use Exception; class EmailValidationService { private $checker; public function __construct() { $apiKey = config('services.tempmailchecker.key'); if (empty($apiKey)) { throw new Exception('TempMailChecker API key not configured'); } $this->checker = new TempMailChecker($apiKey); } public function validateEmail(string $email): bool { try { return !$this->checker->isDisposable($email); } catch (Exception $e) { \Log::warning('TempMailChecker API error: ' . $e->getMessage()); return true; // Fail open } } }
Symfony Integration
// services.yaml services: TempMailChecker\TempMailChecker: arguments: $apiKey: '%env(TEMPMAILCHECKER_API_KEY)%'
WordPress Plugin
use TempMailChecker\TempMailChecker; use Exception; add_filter('registration_errors', function($errors, $sanitized_user_login, $user_email) { try { $checker = new TempMailChecker(get_option('tempmailchecker_api_key')); if ($checker->isDisposable($user_email)) { $errors->add('disposable_email', 'Disposable email addresses are not allowed.'); } } catch (Exception $e) { // Log error but don't block registration error_log('TempMailChecker error: ' . $e->getMessage()); } return $errors; }, 10, 3);
🛠️ Requirements
- PHP 7.4 or higher
- cURL extension
- JSON extension
- Composer (for installation)
📝 License
This library is open-source software licensed under the MIT License.
🤝 Support
- Documentation: tempmailchecker.com/docs
- Issues: GitHub Issues
- Email: support@tempmailchecker.com
⭐ Why TempMailChecker?
- 277,000+ domains in our database
- Sub-millisecond API processing
- ~70ms latency from global endpoints
- Auto-updates daily
- Free tier with 25 requests/day
- No SDK dependencies - works with any PHP version
Made with ❤️ by TempMailChecker
统计信息
- 总下载量: 2
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-12-18