web-dev-qa-db-ja.com

Facebook:ユーザーが管理者であるページのリストを取得する

グラフAPIを使用しています。

ログインしているユーザーがいて、そのユーザーが管理者であるすべてのページのページIDのリストを取得したい。

これを行う方法はありますか?ドキュメントはかなり悪い-と循環します。

71
EoghanM

Graph APIを使用すると簡単です。手順:

  1. manage_pagesユーザーからの許可(拡張許可)。
  2. Graph APIを呼び出します- https://graph.facebook.com/me/accounts

この手順は、 グラフエクスプローラーでテストできます -> 'Get Access Token'ボタン-> 'をクリックするだけです拡張許可」「manage_pages」を確認して送信します。 admin-page-details JSONが提供されます。

132
Avi C

私はいくつかのFQLでそれを解決しました:

FB.api({method: 'fql.multiquery',
        access_token: <access_token>,
        queries: {
            query1: 'select page_id from page_admin where uid = ' + <uid>,
            query2: 'select page_id, name, page_url from page where page_id in (select page_id from #query1)'
        }
       }, function(queries){
           var pages = queries[1].fql_result_set;
       }}
13
EoghanM

FQLを使用したくない場合は、FB.api(/me/accounts)を呼び出すことができます。

「アカウント」は、ユーザーオブジェクトの接続です。このドキュメントを参照してください@ http://developers.facebook.com/docs/reference/api/user

もちろん、Facebookでは常にキャッチがあります。現在、このメソッドは、ユーザーが管理者であるページだけでなく、インストールしたアプリケーションも返します。私はこれが意図した動作ではないことをほぼ確信しています-数か月前にこれを使用し、ページのリストのみを取得したことを覚えているようです。ドキュメントでは、このリストのアプリケーションについても言及していません。

しかし、これは簡単に解決できる問題です。Facebookはリストの各アイテムの名前、カテゴリ、IDを返し、各アプリケーションには「アプリケーション」というカテゴリがあります。カテゴリが「アプリケーション」ではないアイテムのみをリストするようにしています。

11

この住所に行く

https://developers.facebook.com/tools/Explorer/431294226918345/?method=GET&path=me%2Faccounts%3Ftype%3Dpage `

get access tokenをクリックして、extended Permissionに移動するだけです

manage_pagesチェックボックスをオンにします

およびGet Access Tokenをクリック

次に、FQLの下にこれを書きます

me/accounts?type = page

Submitをクリックします。ユーザーadminにログインしたすべてのページリストを取得します

10
Tarun Gupta

ログイン時にJavaScript SDKで許可を求めます

FB.login(function(){}, {perms:'manage_pages'});

そして、彼らがログインすると、次のようにページ(およびアプリ)を取得できます。

FB.api('/me/accounts', function(response){
    console.log(response);
})
7
Mohamed Turki

ユーザーが管理しているFacebookページのリストのみが必要な場合は、「pages_show_list」権限を使用することもできます。

「manage_pages」権限は、ユーザーに自分のページを管理する権限を要求します。これは、必要なものによっては非常に煩わしい場合があります。

6
gneto

許可

$facebook->getLoginUrl( array( "scope" => "manage_pages" ) );

アクション

$accounts = $facebook->api('/me/accounts');  
return $accounts;

ソリューションはPages およびApplicationsを返すことに注意してください。 Pagesのみが必要な場合は、次のような「Type not equals」句を使用してFQL Multiqueryを使用できます。

{
"query1":"select page_id from page_admin where uid = me()",
"query2":"select page_id, name, page_url, type from page where type!='APPLICATION' AND page_id in (select page_id from #query1)"
}
5
dbau
<head>
 <link rel="stylesheet" href="@Url.Content("~/Content/jquery.remodal.css")">
</head>

<body>
<script type="text/javascript" src="@Url.Content("~/Scripts/Home/jquery.remodal.js")"></script>
<div class="remodal" id="page-selector-remodal" data-remodal-id="pageselector">
        <p>Please select a facebook page Share </p>
        <div id="page-name-container">
            <select id="page-name" class="form-control">
            </select>
        </div>
        <a class="remodal-confirm" id="facebookPageSelectSubmit" href="#">OK</a>
        <a class="remodal-cancel" id="remodal-cancel" href="#">CANCEL</a>
    </div>

    <div data-remodal-id="modal-status">
        <p id="modal-status-content">
            The Account you have selected does not have Email.
        </p>
        <br>
        <a class="remodal-confirm" href="#">OK</a>
    </div>
<script type="text/javascript>
 (function (d, s, id) {
            var js, fjs = d.getElementsByTagName(s)[0];
            if (d.getElementById(id)) return;
            js = d.createElement(s);
            js.id = id;
            js.src = "//connect.facebook.net/en_US/sdk.js";
            fjs.parentNode.insertBefore(js, fjs);
        }(document, 'script', 'facebook-jssdk'));

        window.fbAsyncInit = function () {
            FB.init({
                appId: 'YOUR APP ID',
                cookie: true,  // enable cookies to allow the server to access 
                // the session
                xfbml: true,  // parse social plugins on this page
                version: 'v2.2' // use version 2.1
            });
        };

        var pageSelector = $('[data-remodal-id=pageselector]').remodal();
        var modalstatus = $('[data-remodal-id=modal-status]').remodal();

        function statusChangeCallback(response) {

            if (response.status === 'connected') {
                // Logged into your app and Facebook.
                //testAPI();
            } else if (response.status === 'not_authorized') {
                // The person is logged into Facebook, but not your app.
                $("#modal-status-content").empty().html(response.status);
                modalstatus.open();
            }

            else {
                $("#modal-status-content").empty().html(response.status);
                modalstatus.open();
                // The person is not logged into Facebook, so we're not sure if
                // they are logged into this app or not.
                document.getElementById('status').innerHTML = 'Please log ' +
                    'into Facebook.';
            }
        }


        function FacebookHandler() {
            FB.login(function (result) {
                if (result != null && result.authResponse != null && result.authResponse != undefined) {
                    facebookPageData = result;
                    FB.api('/me/accounts', function (accountsResult) {
                        if (accountsResult != null && accountsResult.data.length != 0) {
                            //open the remodal here
                            pageSelector.open();
                            facebookAccountsData = accountsResult;
                            var data = accountsResult['data'];
                            if (data != null) {
                                for (var i = 0; i < data.length; i++) {
                                    $("#page-name").append('<option value="' + data[i].id + '">' + data[i].name + '</option>');
                                }
                            }
                            unblockUI('body');
                            $("#flip-container, #feature-container, #branding-container, #intro-arrow-container, #share-container, #copyright-text-container").hide();
                            $("body").css("padding-right", "0");
                        }
                        else {
                            $("#modal-status-content").empty().html("The Account you have selected does not have any facebook page,<br />Post to Wall.");
                            modalstatus.open();
                            pageSelector.open();
                            unblockUI('body');
                        }
                    });
                }
                else {
                    $("#modal-status-content").empty().html("Unable to retrieve your details from facebook, try again after sometime.");
                    modalstatus.open();
                    unblockUI('body');
                }
            }, { scope: 'manage_pages, publish_stream' });
        }

        $("#facebookPageSelectSubmit").on("click", function () {
            var facebookpageId = $("#page-name option:selected").val();
            if (facebookpageId != null) {
                FB.api('/' + facebookpageId, function (identity) {

                    if (identity != null) {
                        FB.api('/' + facebookpageId, { fields: 'access_token' }, function (resp) {
                            if (resp.access_token != null) {
                                //Get the "resp"(Data) here
                        }
                        else {

                        }

                    });
                }

                else {

                }
            });
        }
        else {

        }
    });
</script>

//Finally call the "FacebookHandler()" function on click


</body>
1

JavaScriptを使用した新しいGRAPH API v3では、「perms」フィールドの代わりに「tasks」フィールドを使用します。

//Example JS Call
FB.api('/me/accounts?fields=name,picture.type(square),access_token,tasks', function(response) {console.log(response)});

//Example Response
{
      "name": "Engage",
      "picture": {
        "data": {
          "height": 50,
          "is_silhouette": false,
          "url": "https://scontent.xx.fbcdn.net/v/t1.0-1/c1.0.50.50a/p50x50/430597_259746387431503_2144341304_n.jpg?_nc_cat=103&_nc_eui2=AeGVrU8Wxe7k5BMvRXOEAcUo9dMIxyeMP9POPkYDwfgdRl8QquAtz1GcwXpJaK4z_0o&_nc_ht=scontent.xx&oh=e5b952a4adbbcd1b1af6b71b688f7284&oe=5CF9A64C",
          "width": 50
        }
      },
      "access_token": "XXXXXXXXXX",
      "id": "253263371413138",
      "tasks": [
        "ANALYZE",
        "ADVERTISE",
        "MODERATE",
        "CREATE_CONTENT",
        "MANAGE"
      ]
    }

配列内で「ADMINISTER」を探す代わりに、「MANAGE」を探します。

ここに完全な情報: https://developers.facebook.com/docs/pages/access-tokens

0
Jason Engage