serafim / graph-sdk
与 PHP 8.1 兼容的 Facebook SDK
7.0.3
2022-03-16 14:56 UTC
Requires
- php: ^8.0
Requires (Dev)
- guzzlehttp/guzzle: ^7.4
- mockery/mockery: ^1.5.0
- phpunit/phpunit: ^9.5.18
- rector/rector: ^0.12.17
- vimeo/psalm: ^4.22
Replaces
- facebook/graph-sdk: >=5.7.0
README
警告:这是一个与 PHP 8.0+ 兼容的定制版本
此仓库包含开源 PHP SDK,允许您从 PHP 应用程序访问 Facebook 平台。
安装
Facebook PHP SDK 可以通过 Composer 安装。运行此命令
composer require serafim/graph-sdk
请注意,当与 Guzzle 6.x 或更低版本一起使用时,存在问题。 serafim/php-graph-sdk
v7.x 默认情况下仅与 Guzzle 7.x+ 兼容。然而,存在一种解决方案,使其与 Guzzle 6.x 兼容。
升级到 v5.x
从 v4.x 升级?Facebook PHP SDK v5.x 引入了破坏性变更。升级前请阅读升级指南。
用法
用户个人资料简单 GET 示例。
require_once __DIR__ . '/vendor/autoload.php'; // change path as needed $fb = new \Facebook\Facebook([ 'app_id' => '{app-id}', 'app_secret' => '{app-secret}', 'default_graph_version' => 'v2.10', //'default_access_token' => '{access-token}', // optional ]); // Use one of the helper classes to get a Facebook\Authentication\AccessToken entity. // $helper = $fb->getRedirectLoginHelper(); // $helper = $fb->getJavaScriptHelper(); // $helper = $fb->getCanvasHelper(); // $helper = $fb->getPageTabHelper(); try { // Get the \Facebook\GraphNodes\GraphUser object for the current user. // If you provided a 'default_access_token', the '{access-token}' is optional. $response = $fb->get('/me', '{access-token}'); } catch(\Facebook\Exceptions\FacebookResponseException $e) { // When Graph returns an error echo 'Graph returned an error: ' . $e->getMessage(); exit; } catch(\Facebook\Exceptions\FacebookSDKException $e) { // When validation fails or other local issues echo 'Facebook SDK returned an error: ' . $e->getMessage(); exit; } $me = $response->getGraphUser(); echo 'Logged in as ' . $me->getName();
完整的文档、安装说明和示例可在此处找到 这里。
测试
- 运行测试之前,需要先安装 Composer。全局安装 composer,然后运行
composer install
安装所需的文件。 - 在 Facebook Developers 上创建测试应用程序,然后从
tests/FacebookTestCredentials.php.dist
创建tests/FacebookTestCredentials.php
并编辑它以添加您的凭据。 - 可以通过从根目录运行此命令来执行测试
$ ./vendor/bin/phpunit
默认情况下,测试将通过 Graph API 发送实时 HTTP 请求。如果您没有互联网连接,可以通过排除 integration
组来跳过这些测试。
$ ./vendor/bin/phpunit --exclude-group integration
贡献
为了接受您的贡献,您必须首先签署贡献者许可协议。请参阅CONTRIBUTING 以获取详细信息。
许可
有关更多信息,请参阅许可文件。
安全漏洞
如果您发现了一个安全问题,请直接联系维护者 me@sammyk.me。