グラフAPIを使用しています。
ログインしたユーザーがいて、そのユーザーが管理しているすべてのページのページIDのリストを取得したいと考えています。
これを行う方法はありますか?ドキュメントはかなり悪いです-そして循環しています。
回答:
GraphAPIを使用すると簡単です。手順:
manage_pages
ユーザーからアクセス許可を取得します(拡張アクセス許可)。この手順は、グラフエクスプローラーでテストできます-> [アクセストークンの取得]ボタンをクリックします-> [拡張アクセス許可]の下の[manage_pages]をチェックして送信します。admin-page-detailsJSONが表示されます。
私はいくつかの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;
}}
FB.api(/me/accounts)
FQLを使用したくない場合は、電話をかけることができます。
「アカウント」は、ユーザーオブジェクトの接続です。この@http ://developers.facebook.com/docs/reference/api/userのドキュメントを参照してください
もちろん、Facebookでは常に問題があります。現在、このメソッドは、ユーザーが管理しているページだけでなく、ユーザーがインストールしたアプリケーションも返します。私はこれが意図された動作ではないことをほぼ確信しています-数ヶ月前にこれを使用し、ページのリストのみを取得したことを覚えているようです。ドキュメントには、このリストのアプリケーションについても言及されていません。
ただし、これは簡単に解決できる問題です。Facebookはリストの各アイテムの名前、カテゴリ、IDを返し、各アプリケーションには「アプリケーション」のカテゴリがあります。カテゴリが「アプリケーション」ではないアイテムのみをリストするようにしているだけです。
このアドレスに移動します
[アクセストークンの取得]をクリックして、拡張アクセス許可に移動するだけです
manage_pagesチェックボックスをオンにします
そして アクセストークンを取得]をクリックします
次に、FQLの下にこれを書きます
me / account?type = page
[送信]をクリックします。そして、ユーザー管理者にログインしたすべてのページリストを取得します
me/accounts
サポートtype
するものはどこにありますか?
ソリューションはアプリケーションだけでなくページも返すことに注意してください。Pagesが厳密に必要な場合は、次のような「Typenotequals」句を指定してFQLMultiqueryを使用できます。
{
"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)"
}
許可
$facebook->getLoginUrl( array( "scope" => "manage_pages" ) );
アクション
$accounts = $facebook->api('/me/accounts');
return $accounts;
<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>
Javascriptを備えた新しいGRAPHAPI 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