FacebookService.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. <?php
  2. namespace App\Services\Smm;
  3. use App\Services\Contracts\SmmPlatformInterface;
  4. use Illuminate\Http\Request;
  5. use Facebook\Facebook;
  6. class FacebookService implements SmmPlatformInterface
  7. {
  8. public $fb = null;
  9. public $pageAccessToken = null;
  10. public function __construct() {
  11. $this->fb = new Facebook([
  12. 'app_id' => env('SSM_FACEBOOK_APP_ID'), // 替换为您的App ID
  13. 'app_secret' => env('SSM_FACEBOOK_APP_SECRET'), // 替换为您的App Secret
  14. 'default_graph_version' => 'v22.0', // 使用当前版本
  15. ]);
  16. //$this->pageAccessToken = $pageAccessToken;
  17. }
  18. /*
  19. * OAuth 2.0 授权登录
  20. * 返回授权地址:https://example.com/fb-callback.php
  21. */
  22. public function login()
  23. {
  24. // 实现Facebook登录逻辑
  25. $helper = $this->fb->getRedirectLoginHelper();
  26. $permissions = ['public_profile','email'];
  27. $state = $helper->getPseudoRandomString(16); // Generate a random state
  28. session(['facebook_oauth_state' => $state]); // Store in Laravel session
  29. $loginUrl = $helper->getLoginUrl(env('DIST_SITE_URL').'/open/callback/facebook', $permissions);
  30. return ['status'=>true, 'data' => ['url'=>$loginUrl]];
  31. }
  32. /*
  33. * OAuth 2.0 授权回调
  34. * 授权成功后,得到access_token,refresh_token等信息, 保存到数据库中
  35. * 授权成功后,返回回调需要的数据
  36. */
  37. public function loginCallback(Request $request)
  38. {
  39. // 实现Facebook回调处理
  40. $helper = $this->fb->getRedirectLoginHelper();
  41. // Validate the state parameter
  42. $storedState = session('facebook_oauth_state');
  43. $returnedState = $request->input('state');
  44. if (!$storedState || $storedState !== $returnedState) {
  45. return ['status' => false, 'data' => 'CSRF validation failed: State parameter mismatch'];
  46. }
  47. try {
  48. $accessToken = $helper->getAccessToken();
  49. } catch (Facebook\Exceptions\FacebookResponseException $e) {
  50. return ['status' => false, 'data' => 'Graph API错误:' . $e->getMessage()];
  51. } catch (Facebook\Exceptions\FacebookSDKException $e) {
  52. return ['status' => false, 'data' => 'SDK错误:' . $e->getMessage()];
  53. }
  54. if (isset($accessToken)) {
  55. // 可选:将短期令牌转换为长期令牌(有效期约60天)
  56. $oAuth2Client = $this->fb->getOAuth2Client();
  57. $longLivedAccessToken = $oAuth2Client->getLongLivedAccessToken($accessToken);
  58. $useriInfo = $this->getFacebookUser($longLivedAccessToken);
  59. return ['status' => true, 'data' => ['access_token' => $longLivedAccessToken,'user_name'=>$useriInfo['name'],'user_id'=>$useriInfo['id']]];
  60. } else {
  61. return ['status' => false, 'data' => '无法获取访问令牌'];
  62. }
  63. }
  64. public function postImage($message,$imagePath) {
  65. try {
  66. $response = $this->fb->post(
  67. '/me/photos',
  68. [
  69. 'source' => $this->fb->fileToUpload($imagePath), // 上传图片文件
  70. 'message' => $message, // 添加描述
  71. ],
  72. $this->userAccessToken
  73. );
  74. $graphNode = $response->getGraphNode();
  75. return ['status' => true, 'data' => ['id' => $graphNode['id']]];
  76. } catch (Facebook\Exceptions\FacebookResponseException $e) {
  77. $errorMsg = 'Graph API错误:' . $e->getMessage();
  78. } catch (Facebook\Exceptions\FacebookSDKException $e) {
  79. $errorMsg = 'SDK错误:' . $e->getMessage();
  80. }
  81. return ['status'=>false,'data' => $errorMsg];
  82. }
  83. public function postVideo($message,$videoPath) {
  84. try {
  85. $response = $this->fb->post(
  86. '/me/videos',
  87. [
  88. 'source' => $this->fb->fileToUpload($videoPath), // 上传视频文件
  89. 'title' => $message, // 添加标题
  90. 'description' => '', // 添加描述
  91. ],
  92. $this->userAccessToken
  93. );
  94. $graphNode = $response->getGraphNode();
  95. return ['status' => true, 'data' => ['id' => $graphNode['id']]];
  96. } catch (Facebook\Exceptions\FacebookResponseException $e) {
  97. $errorMsg = 'Graph API错误:' . $e->getMessage();
  98. } catch (Facebook\Exceptions\FacebookSDKException $e) {
  99. $errorMsg = 'SDK错误:' . $e->getMessage();
  100. }
  101. return ['status'=>false,'data' => $errorMsg];
  102. }
  103. public function getComments($postId) {
  104. }
  105. public function replyToComment($commentId) {
  106. }
  107. public function deleteComment($commentId) {
  108. }
  109. /**
  110. * 获取Facebook用户信息
  111. * @param string $accessToken
  112. * @return array [
  113. * 'name' => string,
  114. * 'id' => string,
  115. * 'error' => string|null
  116. * ]
  117. */
  118. public function getFacebookUser($accessToken)
  119. {
  120. try {
  121. // 验证并设置访问令牌
  122. $this->fb->setDefaultAccessToken($accessToken);
  123. // 发送请求获取用户信息
  124. $response = $this->fb->get('/me?fields=name,id');
  125. $userNode = $response->getGraphUser();
  126. return [
  127. 'name' => $userNode->getName(),
  128. 'id' => $userNode->getId(),
  129. 'error' => null
  130. ];
  131. } catch (FacebookResponseException $e) {
  132. // API 响应错误处理
  133. return [
  134. 'name' => null,
  135. 'id' => null,
  136. 'error' => 'Graph API Error: ' . $e->getMessage()
  137. ];
  138. } catch (FacebookSDKException $e) {
  139. // SDK 错误处理
  140. return [
  141. 'name' => null,
  142. 'id' => null,
  143. 'error' => 'SDK Error: ' . $e->getMessage()
  144. ];
  145. } catch (Exception $e) {
  146. // 其他错误处理
  147. return [
  148. 'name' => null,
  149. 'id' => null,
  150. 'error' => 'General Error: ' . $e->getMessage()
  151. ];
  152. }
  153. }
  154. }