Позвольте мне поделиться некоторыми идеями
Во-первых, я настоятельно рекомендую вам использовать Facebook C # SDK от Microsoft вместо простых вызовов в вашем .NET-проекте.
Шаги
С помощью текущего API вы можете сделать это на своей странице ADMIN
- Попросить пользователя подключиться и запросить разрешение на управление страницами (
manage_page
) - с разрешениями для управления страницами вы можете легко заполнить раскрывающийся список всеми страницами, которые есть у пользователя
- Попросить пользователя добавить ваше приложение на свою страницу в качестве вкладки, используя
http://facebook.com/add.php?api_key=[API_KEY]&pages=1&page=[PAGE_ID]
Теперь, когда ваше приложение запущено на странице пользователя, вам нужен способ проверить, работает ли эта страница внутри Facebook в виде вкладки или нет, и с чего запускается идентификатор страницы.
- На указанной вами странице URL-адреса вкладки приложения попросите
signed_request
и проверьте Data
, так как он имеет ["page"]["id"]
, который вам нужен, чтобы вы моглипроверьте по сохраненным Page_Id, что вы должны были сохранить на ADMINкогда ваш пользователь добавит ваше приложение на свою страницу в Facebook.
Надеюсь, это поможет.
Код
Для входа в систему и запрос всех страниц пользователя :
<select class="facebook-page-list" disabled="disabled">
<option>Facebook pages</option></select>
<script>
<!--
FB.init({
appId: 'API_KEY',
cookie: true,
status: true,
xfbml: true
});
FB.api('/me', function (user) {
if (user != null) {
if (user.error) {
$(".fb-login").show();
} else {
// example from Facebook
var image = document.getElementById('image');
image.src = 'https://graph.facebook.com/' + user.id + '/picture';
var name = document.getElementById('name');
name.innerHTML = user.name
// get all user Pages
facebookGetPages();
}
}
});
function facebookGetPages() {
FB.getLoginStatus(function (response) {
if (response.session) {
access_token = response.session.access_token;
FB.api(
{
method: 'fql.multiquery',
access_token: access_token,
queries: {
query1: 'select page_id from page_admin where type <> "APPLICATION" and uid = ' + response.session.uid,
query2: 'select page_id, name, page_url from page where page_id in (select page_id from #query1)'
}
}, function (queries) {
if (queries.error_msg)
alert(queries.error_msg);
else {
pages = queries[1].fql_result_set;
$(".facebook-page-list").empty();
for (i = 0; i < pages.length; i++)
$(".facebook-page-list").append("<option value='" + pages[i].page_id + "'>" + pages[i].name + "</option>");
$(".facebook-page-list").attr("disabled", false);
}
});
} else {
// no user session available, someone you dont know
}
});
}
//-->
</script>
Чтобы получить идентификатор страницы из вашего приложения:
ViewBag.signed_request = "can't get id";
dynamic signed_request = FacebookWebContext.Current.SignedRequest;
if(signed_request != null)
{
ViewBag.signed_request = signed_request.Data.page.id;
}