Как опубликовать статью, используя Open Graph на временной шкале?
Последние восемь часов я работал не покладая рук, пытаясь отформатировать свой блог Wordpress таким образом, чтобы пользователь мог нажать кнопку и опубликовать статью в тикере, используя настройки Open Graph для Article.
Я использовал учебник, найденный здесь.
К сожалению, я не смог завершить его, так как каждый раз, когда я нажимаю кнопку "Опубликовать", которую я создал, появляется сообщение об ошибке.
При использовании отладчика Facebook я не вижу проблем, и все необходимые теги на месте (у меня есть плагин, который делает это для меня, что идеально).
Вот изменения, которые я внес в мой header.php
файл, чтобы соответствовать учебнику:
<html xmlns="http://www.w3.org/1999/xhtml" dir="ltr" lang="en-US"
xmlns:fb="https://www.facebook.com/2008/fbml">
Добавил следующее раньше </head>
:
<script type="text/javascript">
function postArticle()
{
FB.api(
'/me/[NAMESPACE]:read?Article=<?php get_permalink() ?>',
'post',
function(response) {
if (!response || response.error) {
alert('Error occured');
} else {
alert('Successful! Action ID: ' + response.id);
}
});
}
</script>
Размещена кнопка входа в систему, которая запрашивает разрешение:
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({
appId : '[APPLICATION ID]', // App ID
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
};
// Load the SDK Asynchronously
(function(d){
var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
d.getElementsByTagName('head')[0].appendChild(js);
}(document));
</script>
<fb:login-button perms="email,publish_actions,user_actions.news">
Login with Facebook
</fb:login-button>
И, наконец, поместил следующее в той точке на странице, где я хочу, чтобы кнопка появилась:
<fb:add-to-timeline></fb:add-to-timeline>
<form>
<input type="button" value="Publish" onclick="postArticle()" />
</form>
В моих настройках Open Graph у меня есть тип действия "Чтение", а также тип объекта "Статья".
Почему это не работает для меня?
2 ответа
Это работает для меня, через этот учебник.
Вы добавили теги opengraph в свой головной раздел, как...
<head prefix="og: http://ogp.me/ns# [YOUR_APP_NAMESPACE]:
http://ogp.me/ns/apps/[YOUR_APP_NAMESPACE]#">
<title>OG Tutorial App</title>
<meta property="fb:app_id" content="[YOUR_APP_ID]" />
<meta property="og:type" content="[YOUR_APP_NAMESPACE]:recipe" />
<meta property="og:title" content="[YOUR_TITLEIts]" />
<meta property="og:image" content="http://fbwerks.com:8000/zhen/cookie.jpg" />
<meta property="og:description" content="The Turducken of Cookies" />
<meta property="og:url" content="http://fbwerks.com:8000/zhen/cookie.html">
</head>