1. 程式人生 > >Facebook獲取AccessToken和獲取個人主頁資訊

Facebook獲取AccessToken和獲取個人主頁資訊

一、開始的準備工作

  • (1)建立你自己的應用

這裡寫圖片描述

  • (2)填寫建立應用的資訊

這裡寫圖片描述

  • (3)建立成功
    [應用建立完成會生成對應的AppId和AppSecret還有對應的版本號]

這裡寫圖片描述

  • (4)新增產品
    [這裡我們需要登入,因為我們要通過登入獲取他的AccessToken]

這裡寫圖片描述

[把下面三個按鈕開啟,設定登入成功AccessToken的回傳地址 注意:必須在伺服器或者雲伺服器上進行操作,指定的地址必須可以訪問不能是區域網的ip,不能在本地localhost下進行]

指定到控制器的某個方法就可以了路徑必須正確,失敗時候檢查伺服器是否開啟路由重寫模式,沒有開啟要加index.php

這裡寫圖片描述

把Facebook這個目錄的檔案放到自己專案對應的目錄下
這裡寫圖片描述

我是用TP做的,所有我把他放在Queens\ThinkPHP\Library\Vendor\Facebook

這裡寫圖片描述

二、程式碼實現

  • (1)login
<?php
namespace Admin\Controller;

use Facebook\Facebook;
use Think\Controller;

class FaceController extends CommonController
{
    private $app_id='';
    private $app_secret
=''; private $fb=''; public function _initialize() { parent::_initialize(); vendor('Facebook.autoload'); $this->_getAppId(); } private function _getAppId() { $map=array('type'=>'facebook_appid'); $m=M('info')->field('info')->where($map
)->find(); $arr=json_decode($m['info'],true); $this->app_id=$arr['app_id']; $this->app_secret=$arr['app_secret']; $this->_getFb($this->app_id,$this->app_secret); } /** 我這裡是通過資料庫儲存的App Id,和App Secret,最好是這樣,不要在控制那裡寫死,因為這些東西 可以在Facebook那裡更改,最好彈性一點反正都可以,只有組裝成像下面$fb的格式就可以! */ private function _getFb($app_id,$app_secret) { $fb = new Facebook([ 'app_id' => $app_id, 'app_secret' => $app_secret, 'default_graph_version' => 'v2.8',//[注意:最好要對應自己php的sdk版本號] ]); $this->fb=$fb; } /** 把登陸按鈕的資訊返回頁面,因為Facebook的AccessToken他是有時間限定的,不是永久, 而且必須要通過登陸才能獲取所有這裡吧登陸的資訊做成一個更新AccessToken的按鈕, 讓管理員去更新,可以自己判斷AccessToken,寫個定時更新都可以,我這裡是為了簡單實現! */ public function index() { $fb=$this->fb; $helper = $fb->getRedirectLoginHelper(); $url='這裡是你自己等會後的回傳地址nsdining/index.php/Admin/Face/showFace'; $loginUrl = $helper->getLoginUrl($url); $this->assign('data',htmlspecialchars($loginUrl)); $this->display(); } /** 登陸後Facebook伺服器會讓你跳到你自己定義的這個方法,還有帶回Facebook給 你的AccessToken, */ public function showFace() { $fb=$this->fb; $helper = $fb->getRedirectLoginHelper(); try { $accessToken = $helper->getAccessToken(); } 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; } if (! isset($accessToken)) { if ($helper->getError()) { header('HTTP/1.0 401 Unauthorized'); echo "Error: " . $helper->getError() . "\n"; echo "Error Code: " . $helper->getErrorCode() . "\n"; echo "Error Reason: " . $helper->getErrorReason() . "\n"; echo "Error Description: " . $helper->getErrorDescription()."\n"; } else { header('HTTP/1.0 400 Bad Request'); echo 'Bad request'; } exit; } // Logged in // echo '<h3>Access Token</h3>'; // var_dump($accessToken->getValue()); // OAuth 2.0 client handler $oAuth2Client = $fb->getOAuth2Client(); // Exchanges a short-lived access token for a long-lived one $longLivedAccessToken = $oAuth2Client->getLongLivedAccessToken($accessToken->getValue()); // The OAuth 2.0 client handler helps us manage access tokens $oAuth2Client = $fb->getOAuth2Client(); // Get the access token metadata from /debug_token $tokenMetadata = $oAuth2Client->debugToken($accessToken); // echo '<h3>Metadata</h3>'; $token_time_out_json=json_encode($accessToken->getExpiresAt()); $token_time_out_json_time=explode('.',json_decode($token_time_out_json,true)['date']); // pr($tokenMetadata->getExpiresAt()->date); // Validation (these will throw FacebookSDKException's when they fail) $tokenMetadata->validateAppId($this->app_id); // Replace {app-id} with your app id // If you know the user ID this access token belongs to, you can validate it here //$tokenMetadata->validateUserId('123'); $tokenMetadata->validateExpiration(); if (! $accessToken->isLongLived()) { // Exchanges a short-lived access token for a long-lived one try { $accessToken = $oAuth2Client->getLongLivedAccessToken($accessToken); } catch (Facebook\Exceptions\FacebookSDKException $e) { echo "<p>Error getting long-lived access token: " . $helper->getMessage() . "</p>\n\n"; exit; } // echo '<h3>Long-lived</h3>'; } $_SESSION['fb_access_token'] = (string) $accessToken; //獲取到了AccessToken,接下來的處理,你可以存在session或者資料庫都可,只要能隨時拿就ok, //我這裡是寫在檔案那裡 $accessTokenArr=array( 'Facebook_token'=>$accessToken->getValue(), //AccessToken值 'time_out'=>$token_time_out_json_time[0] //AccessToken過期的時間 ); file_put_contents('./Public/key/facebookToken.txt',json_encode($accessTokenArr)); if( $this->_updateFacebookAccessToken($accessTokenArr)){ echo "<script>alert('update successfully');window.location.href='".U('Face/index')."'</script>"; }else{ echo "<script>alert('Failed to update');window.location.href='".U('Face/index')."'</script>"; } // User is logged in with a long-lived access token. // You can redirect them to a members-only page. //header('Location: https://example.com/members.php');//可以跳到你指定的頁面 } }

三、去Facebook那裡拿資料

  • (1)Facebook官網那裡有個可以測試的工具

這裡寫圖片描述

[這裡是我要拿的資料!]

這裡寫圖片描述

    $url = "https://graph.facebook.com/主頁id或者me?fields=posts{permalink_url,full_picture,message}&access_token=AccessToken值";//也可以分頁獲取,這裡我就不測試了,具體看開發文件
  • (2)拿回來的資料放到自己對應的前端就可以了顯示了[要開VPN,不然就顯示不了]
  • -

這裡寫圖片描述

[點選後可以跳對對應Facebook的動態]

這裡寫圖片描述