rdcstarr/laravel-easyapi 问题修复 & 功能扩展

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

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

rdcstarr/laravel-easyapi

最新稳定版本:v1.1.5

Composer 安装命令:

composer require rdcstarr/laravel-easyapi

包简介

A simple settings package for Laravel.

README 文档

README

Latest Version on Packagist Tests Code Style Downloads

Lightweight package for managing API keys in Laravel — with middleware protection, logging and simple CLI tools.

✨ Features

  • 🔑 API key management — generate, list, reveal and delete API keys via an artisan command or programmatically.
  • 🛡 Middleware protection — a lightweight middleware validates Bearer tokens on incoming requests.
  • 📈 Usage metrics — each key tracks an access count and API access is logged to api_logs.
  • 🔒 Secure keys — keys are generated using SHA-256 with unique identifiers to avoid collisions.
  • ⚙️ Facade & manager — programmatic API via the EasyApi facade or the EasyApiManager service.
  • 🧪 Test-friendly — models and factories included to make testing straightforward.
  • 📦 Migrations included — package ships migrations for api and api_logs tables and can be published.

📦 Installation

composer require rdcstarr/laravel-easyapi

Automatic Installation (Recommended)

Run the install command to publish and run the migrations:

php artisan easyapi:install

Manual Installation

Alternatively, you can install manually:

  1. Publish the migrations:
php artisan vendor:publish --tag=easyapi-migrations
  1. Run the migrations:
php artisan migrate

The package registers a singleton manager and console commands. It will also register route groups if you provide routes/api.php or routes/web.php.

🔑 Usage

Facade examples (programmatic):

use Rdcstarr\EasyApi\Facades\EasyApi;

// Generate a new API key (returns the Api model)
$api = EasyApi::createKey();
$fullKey = $api->key; // show and store this securely

// Validate a key (returns bool)
$isValid = EasyApi::validateKey($fullKey);

// Delete a key
EasyApi::deleteKey($fullKey);

Middleware usage:

  • The package provides Rdcstarr\EasyApi\Middleware\EasyApiMiddleware which checks for a Bearer token and validates it against the api table. If valid, it logs the request and increments the access count.

Apply it to a route or route group:

Route::middleware([\Rdcstarr\EasyApi\Middleware\EasyApiMiddleware::class])->group(function () {
    Route::get('/protected', function () {
        return ['ok' => true];
    });
});

Database schema:

  • api table: id, key (unique), access_count, timestamps
  • api_logs table: id, api_id, endpoint, ip_address, user_agent, timestamps

Artisan CLI:

The package exposes a single console command: php artisan easyapi with the following actions:

  • generate — create a new API key
  • delete --key=KEY — delete an API key (confirmation required)
  • list — display stored API keys (masked) with access counts
  • reveal --id=ID — reveal the full API key for a given id

Examples:

php artisan easyapi generate
php artisan easyapi list
php artisan easyapi delete --key="qwerty_..."
php artisan easyapi reveal --id=1

Notes:

  • Generated keys must be stored securely when created — the generate command shows the full key once.
  • The command output masks keys in listings for safety; use reveal to show the full value when necessary.

🧪 Testing

Run the package tests:

composer test

The package provides models (Api, ApiLog) and factories to make writing tests simpler.

📖 Resources

  • Changelog for more information on what has changed recently.

👥 Credits

📜 License

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-09-18