fragote/phpoauthlib

PHP 7.2 oAuth 1/2 库

v0.8.11.1 2021-07-04 02:33 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的类(包含两个实现)。
    • 您可以使用任何存储机制来存储令牌。默认情况下,包含session、内存和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 Bundle

扩展

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

测试

    composer tests