Facebook使用javascript sdk在我的时间线上共享自定义故事

Facebook使用javascript sdk在我的时间线上共享自定义故事,javascript,facebook,facebook-graph-api,facebook-javascript-sdk,Javascript,Facebook,Facebook Graph Api,Facebook Javascript Sdk,这是一个非常初级的问题,我无法找到解决方案。我花了很多时间阅读他们的官方文件,但都是徒劳的,所以我来到这里是最后的选择。 我想做的 我想在我的时间线上发布我的自定义故事, 1) 我已经创建了一个自定义故事 2) 已尝试通过共享对话框共享它[不起作用],并且还尝试了api调用 <div id="fb-root"></div> <!-- facebook code starts here --> <script> function status

这是一个非常初级的问题,我无法找到解决方案。我花了很多时间阅读他们的官方文件,但都是徒劳的,所以我来到这里是最后的选择。
我想做的
我想在我的时间线上发布我的自定义故事,

1) 我已经创建了一个自定义故事
2) 已尝试通过共享对话框共享它[不起作用],并且还尝试了api调用

<div id="fb-root"></div>

<!-- facebook code starts here -->

<script>
  function statusChangeCallback(response) {
    console.log('statusChangeCallback');
    console.log(response);


  function checkLoginState() {
    FB.getLoginStatus(function(response) {
      statusChangeCallback(response);
    });
  }

  window.fbAsyncInit = function() {
  FB.init({
    appId      : xxxxx[correctly used app id],
    cookie     : true,  // enable cookies to allow the server to access 
    status     : true,           
    xfbml      : true,  // parse social plugins on this page
    version    : 'v2.0' // use version 2.0
  });



  FB.getLoginStatus(function(response) {
    statusChangeCallback(response);
  });




  FB.api(
          'me/objects/restaurant.restaurant',
          'post',
          {
            app_id: xxxxx[correctly used app id],
            type: "restaurant.restaurant",
            url: "http://samples.ogp.me/440002909390231",
            title: "Sample Restaurant",
           image:"https://static.ak.fbcdn.net/images/devsite/attachment_blank.png",
            description: "This place rocks",
            contact_info: "http://www.facebook.com",
            location: "-122.148283"
          },
          function(response) {
            // handle the response
          }
    );


  FB.api(
          'me/testxdev:eat',
          'post',
          {
            restaurant: "http://samples.ogp.me/440002909390231"
          },
          function(response) {
            // handle the response
          }
        );


  };//********END OF FUNCTION ENCLOSING INIT()***********

  // 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/debug.js";
    fjs.parentNode.insertBefore(js, fjs);
  }(document, 'script', 'facebook-jssdk'));


</script>  

 <div class="fb-like" data-send="true" data-width="450" data-show-faces="true"></div>


<!--  End of facebook code-->

函数statusChangeCallback(响应){
log('statusChangeCallback');
控制台日志(响应);
函数checkLoginState(){
FB.getLoginStatus(函数(响应){
状态更改回调(响应);
});
}
window.fbAsyninit=函数(){
FB.init({
appId:xxxxx[正确使用的应用程序id],
cookie:true,//启用cookie以允许服务器访问
状态:正确,
xfbml:true,//解析此页面上的社交插件
版本:“v2.0”//使用版本2.0
});
FB.getLoginStatus(函数(响应){
状态更改回调(响应);
});
FB.api(
“我/物体/餐厅.餐厅”,
"岗位",,
{
应用程序id:xxxxx[正确使用的应用程序id],
类型:“餐厅,餐厅”,
url:“http://samples.ogp.me/440002909390231",
标题:“样本餐厅”,
图像:“https://static.ak.fbcdn.net/images/devsite/attachment_blank.png",
描述:“这个地方岩石”,
联系信息:http://www.facebook.com",
位置:“-122.148283”
},
功能(响应){
//处理响应
}
);
FB.api(
“me/testxdev:吃”,
"岗位",,
{
餐厅:“http://samples.ogp.me/440002909390231"
},
功能(响应){
//处理响应
}
);
};//*******包含INIT()的函数结尾***********
//异步加载SDK
(功能(d、s、id){
var js,fjs=d.getElementsByTagName[0];
if(d.getElementById(id))返回;
js=d.createElement;js.id=id;
js.src=“//connect.facebook.net/en_US/sdk/debug.js”;
fjs.parentNode.insertBefore(js,fjs);
}(文档“脚本”、“facebook jssdk”);

我能够解决我自己的问题,我也发布了解决方案,这样其他人就不会有这样的困难

<div id="fb-root"></div>
<!-- facebook code starts here -->

<script>

  function statusChangeCallback(response) {


    if (response.status === 'connected') {



     FB.api('/me', function(response) {
        console.log("here");
            console.log(JSON.stringify(response));
});  

  FB.api(
         '/me/objects/restaurant.restaurant',
         'post',
         {
           app_id: "[your app id]",
           type: "restaurant.restaurant",
           url: "http://samples.ogp.me/440002909390231",
           title: "Sample Restaurant",
           image: "https://s-static.ak.fbcdn.net/images/devsite/attachment_blank.png",
           description: "This place rocks",
           contact_info: "http://www.facebook.com",
           location: "-122.148283"
         },
         function(response) {
           // handle the response[this helped a lot]
           console.log(JSON.stringify(response));

         }
        ); 

          FB.api(
              '/me/testxdev:eat',
              'post',
              {
            restaurant: "http://samples.ogp.me/440002909390231"
              },
              function(response) {
            // handle the response
              console.log("the action response "+response);
               console.log(JSON.stringify(response));

              }
           );

    } else if (response.status === 'not_authorized') {
      document.getElementById('status').innerHTML = 'Please log ' +
        'into this app.';
    } else {
      document.getElementById('status').innerHTML = 'Please log ' +
        'into Facebook.';
    }
  }


  function checkLoginState() {
    FB.getLoginStatus(function(response) {
      statusChangeCallback(response);
    });
  }

  window.fbAsyncInit = function() {
  FB.init({
    appId      : "[your app id]",
    cookie     : true,  
    status     : true,     
    xfbml      : true,  
    version    : 'v2.0' 
  });

  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/debug.js";
    fjs.parentNode.insertBefore(js, fjs);
  }(document, 'script', 'facebook-jssdk'));


</script>


<fb:login-button scope="public_profile,email,publish_actions",
    auth_type: 'rerequest' onlogin="checkLoginState();">
</fb:login-button>
<div id="status"></div>
 <div class="fb-like" data-send="true" data-width="450" data-show-faces="true"></div>


<!--  End of facebook code-->

函数statusChangeCallback(响应){
如果(response.status===“已连接”){
FB.api('/me',函数(响应){
console.log(“此处”);
log(JSON.stringify(response));
});  
FB.api(
“/me/objects/restaurant.restaurant”,
"岗位",,
{
应用程序id:“[您的应用程序id]”,
类型:“餐厅,餐厅”,
url:“http://samples.ogp.me/440002909390231",
标题:“样本餐厅”,
图像:“https://s-static.ak.fbcdn.net/images/devsite/attachment_blank.png",
描述:“这个地方岩石”,
联系信息:http://www.facebook.com",
位置:“-122.148283”
},
功能(响应){
//处理回应[这帮了大忙]
log(JSON.stringify(response));
}
); 
FB.api(
“/me/testxdev:eat”,
"岗位",,
{
餐厅:“http://samples.ogp.me/440002909390231"
},
功能(响应){
//处理响应
console.log(“操作响应”+响应);
log(JSON.stringify(response));
}
);
}else if(response.status===“未授权”){
document.getElementById('status')。innerHTML='Please log'+
“进入此应用程序。”;
}否则{
document.getElementById('status')。innerHTML='Please log'+
“进入Facebook。”;
}
}
函数checkLoginState(){
FB.getLoginStatus(函数(响应){
状态更改回调(响应);
});
}
window.fbAsyninit=函数(){
FB.init({
appId:“[您的应用程序id]”,
曲奇:是的,
状态:正确,
xfbml:是的,
版本:“v2.0”
});
FB.getLoginStatus(函数(响应){
状态更改回调(响应);
});
};
//异步加载SDK
(功能(d、s、id){
var js,fjs=d.getElementsByTagName[0];
if(d.getElementById(id))返回;
js=d.createElement;js.id=id;
js.src=“//connect.facebook.net/en_US/sdk/debug.js”;
fjs.parentNode.insertBefore(js,fjs);
}(文档“脚本”、“facebook jssdk”);
上述代码工作正常[代码来自自定义创建的故事],主要问题是,默认情况下,共享帖子时,不会出现在时间线上[因为应用程序处于开发模式],因此,要查看帖子,请转到查看最近的活动日志。它必须在那里可见。 如果希望帖子出现在时间线上,请将应用程序仪表板中“状态和审阅”下的应用程序可见性设置为“是”

从2014年起,如果您想向用户发布任何内容[除了应用程序注册开发者]时间表,您需要Facebook许可,即该应用程序需要提交审批,请参考以下链接

您可以检查它是否在概述部分的正下方