PHP 7.2 oAuth 1/2 库

此包的规范仓库似乎已不存在,因此该包已被冻结。

v0.9.0.1 2022-04-14 07:47 UTC

README

注意:我在寻找可以与我一起维护此包的人,因为我不太有时间投入其中。然而,我仍然会尽力关注PR等。

PHPoAuthLib 为 PHP 7.2+ 提供OAuth支持,并且很容易与需要OAuth客户端的任何项目集成。

Build Status Code Coverage Scrutinizer Quality Score Latest Stable Version Total Downloads

安装

此库可在 Packagist 上找到。推荐通过 composer 安装。

    composer require lusitanian/oauth

特性

  • PSR-4
  • 在各个方面都可以完全扩展。
    • 您可以通过扩展协议版本的 AbstractService 实现,来实现任何具有任何自定义要求的服务。
    • 您可以使用您想要的任何HTTP客户端,只需创建一个实现 OAuth\Common\Http\ClientInterface 的类即可(包含两个实现)
    • 您可以使用任何存储机制来存储令牌。默认情况下,包括会话、内存和Redis.io(需要PHPRedis)存储机制。通过实现 OAuth\Common\Token\TokenStorageInterface 来实现额外的机制。

服务支持

该库支持符合OAuth 1.x和OAuth 2.0的服务。以下是当前实现的服务的列表。

包含的服务实现

  • OAuth1
    • 500px
    • BitBucket
    • Etsy
    • FitBit
    • Flickr
    • QuickBooks
    • Scoop.it!
    • Tumblr
    • Twitter
    • Yahoo
  • OAuth2
    • Amazon
    • BitLy
    • Bitrix24
    • Box
    • Buffer
    • Dailymotion
    • Delicious
    • Deezer
    • DeviantArt
    • Dropbox
    • Eve Online
    • Facebook
    • Foursquare
    • GitHub
    • Google
    • Harvest
    • Heroku
    • Hubic
    • Instagram
    • Jawbone UP
    • LinkedIn
    • Mailchimp
    • Microsoft
    • Mondo
    • Nest
    • Netatmo
    • Parrot Flower Power
    • PayPal
    • Pinterest
    • Pocket
    • Reddit
    • RunKeeper
    • Salesforce
    • SoundCloud
    • Spotify
    • Strava
    • Stripe
    • Ustream
    • Vimeo
    • Vkontakte
    • Xing
    • Yahoo
    • Yammer
  • 更多即将到来!

示例

    php -S localhost:8000 -t examples

然后,将您的浏览器指向

    https://:8000/

用法

有关完整认证流程的用法,请参阅示例。更深入的文档将在1.0版本中提供。

框架集成

  • Lithium:Sébastien Charrier 为此库编写了 适配器
  • Laravel 4:Dariusz Prząda 为该库编写了一个 服务提供者
  • Laravel 5:Valentin Ivaşcu 将 Dariusz Prząda 的 Laravel 4 库移植到了 Laravel 5
  • Symfony:Alexander Pinnecke 为该库编写了一个 Symfony 扩展包

扩展

  • 使用 Luciano Mammino 的库 PHPoAuthUserData 从 OAuth 服务中提取标准化用户数据。

测试

    composer tests