1
메신저로 보내기 플러그인을 사용하려고하지만 다른 FB 사용자의 페이지 ID 및 메신저 앱 ID로 초기화하려고하면 렌더링되지 않습니다. 이 사용자는 이미 자신의 페이지를 관리 할 수있는 권한을 부여 받았기 때문에 페이지 ID를 얻을 수 있습니다.메신저로 보내기
흐름 : 페이스 북 SDK와 페이스 북 로그인을 사용하여
- 사용자 로그 아무것도 여기 내가 그것을 할 방법입니다 ..이 시나리오에 대한 메신저 문서에 없습니다. 그는 나에게 manage_pages 권한을 준다.
- 나는 FB.api과의 페이지를 가져 오기 ('ME// 계정')와
- 사용자는
- 내가 선택한 페이지 ID와 메신저 플러그인 요소에 보내기를 만들 페이지 중 하나를 선택 사용자에게 표시 및 내 응용 프로그램 ID를 입력 한 다음 FB.XFBML.parse()를 호출하여 플러그인을 렌더링합니다. 페이지가 앱에 연결되어 있지 않으면 작동하지 않습니다.
내 메신저 봇은 아직 개발되지 않았습니다. 내가 어떤 결과를 이미 시도
것 : - 내 응용 프로그램 에서 만든 테스트 사용자와 시도 - 사용자에게 내 응용 프로그램의 설정에서 테스터 역할을 부여하려고
코드 :
<html>
<body>
<script>
// If user is logged in to FB get his pages
function statusChangeCallback(response) {
if (response.status === 'connected') {
fetchPages();
}
}
// Login listener
function checkLoginState() {
FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
}
// Initialize FB
window.fbAsyncInit = function() {
FB.init({
appId: 'XXXX',
cookie: true,
xfbml: true,
version: 'v2.6'
});
FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
};
// Load the SDK asynchronously
(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'));
function fetchPages() {
FB.api('/me/accounts', function(response) {
if (response && response.data && !response.error) {
// Get all pages managed by the logged in user
var pages = response.data;
var pageIds = [];
pageList.innerHTML = '';
// User selects one of these pages, let's say first one
var selectedPage = pages[0];
var pageSelector = document.getElementById('pageSelector');
pageSelector.addEventListener("click", function() {
// Create the Send to Messenger element with
// messenger_app_id: my app's ID
// page_id: ID of the selected page
var sendToMessengerWrapper = document.getElementById('sendToMessengerWrapper');
sendToMessengerWrapper.innerHTML = '';
var plugin = document.createElement('div');
plugin.setAttribute('class', 'fb-send-to-messenger');
plugin.setAttribute('messenger_app_id', 'XXXX');
plugin.setAttribute('page_id', selectedPage.id);
plugin.setAttribute('data-ref', 'ref');
plugin.setAttribute('color', 'blue');
plugin.setAttribute('size', 'standard');
sendToMessengerWrapper.appendChild(plugin);
// Re-render the button - this only worked the for page directly connected to my app.
FB.XFBML.parse(document.getElementById('sendToMessengerWrapper'));
});
}
});
}
</script>
<!-- Notice the permissions I am requesting -->
<fb:login-button id="logInBtn" scope="manage_pages,pages_messaging,pages_messaging_phone_number" onlogin="checkLoginState();">
</fb:login-button>
<input type="button" id="pageSelector" value="Connect page"/>
<!-- Plugin button should be rendered inside this element -->
<div id="sendToMessengerWrapper"></div>
</body>
감사합니다. 이것은 정확하게 나의 문제였습니다. – orta