paulisratnieks/api-key-auth 问题修复 & 功能扩展

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

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

paulisratnieks/api-key-auth

最新稳定版本:v2.0.1

Composer 安装命令:

composer require paulisratnieks/api-key-auth

包简介

API client authentication, authorization and management

README 文档

README

api-key-auth is a highly customizable Laravel package for API client management, authentication and authorization. The package contains a single middleware ApiClientMiddleware and a few artisan commands to manage the clients.

Installation

You can install the package via composer:

composer require paulisratnieks/api-key-auth

You should publish the config file config/api-key-auth.php and run the migrations to create the api_clients table:

php artisan vendor:publish --provider="PaulisRatnieks\ApiKeyAuth\ApiKeyAuthServiceProvider"
php artisan migrate

Usage

Managing API clients

The package contains multiple artisan commands for API client management: api-client:make, api-client:list, api-client:update.

To create a new client:

php artisan api-client:make

The command will prompt for multiple attributes that are necessary for the ApiClient model. After creation, the command will output the API key in plain text, which should be saved and used to authenticate the API client. The API client has to send an HTTP authorization header with the generated API key Authorization: ApiKey {api-key}.

All the API clients can be viewed with the api-client:list command, and they can be managed with the api-client:update command which supports the following actions: regenerate, revoke, undo-revoke.

Adding the middleware

In config/app.php (Laravel 11 and newer) you should add the middleware to the global middleware stack:

->withMiddleware(function (Middleware $middleware) {
     $middleware->append(\PaulisRatnieks\ApiKeyAuth\ApiClientMiddleware::class);
})

The middleware will validate each request against the HTTP header containing the API key.

Customization

These are the contents of the published config file config/api-key-auth.php:

return [
    // This is the model used by the ApiClientMiddleware.
    'model' => PaulisRatnieks\ApiKeyAuth\ApiClient::class,

    /*
     * These are all the validators used by the ApiClientMiddleware. You can add or remove any classes
     * that implement the PaulisRatnieks\ApiKeyAuth\Validators\Validator interface.
     */
    'validators' => [
        PaulisRatnieks\ApiKeyAuth\Validators\IpAddressValidator::class,
        PaulisRatnieks\ApiKeyAuth\Validators\RevokedValidator::class,
        PaulisRatnieks\ApiKeyAuth\Validators\ScopeValidator::class,
    ],

    // The name of the http header that will be used for authentication.
    'header' => 'Authorization',

    // The key that will hold the authorization header's api key.
    'header_key' => 'ApiKey',
];

It is possible to configure:

  • which model is used by the middleware using the model config entry
  • which validators the middleware uses by the validators entry
  • the HTTP header format using header amd header_key entries. The HTTP header sent by the API clients should follow this format: {header}: {header_key} {api-key}.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-01-30