3

我试图在此处的示例之后对我的代码进行建模:http ://connect.soundcloud.com/examples/connecting.html#

它适用于Firefox,但不适用于chrome。在 chrome 中,soundcloud 弹出窗口正确显示,我可以登录(返回 sc-connect.html),但随后窗口不会关闭。经过仔细检查,由于 window.opener 为空,因此存在 javascript 错误。我想知道它是否与localhost uri有关?上面链接中的示例适用于 firefox 和 chrome。有任何想法吗?我的代码如下:

SC.initialize({client_id:'my_client_id', redirect_uri:'http://localhost:3000/sc-connect.html'});

$('button').click(function(){
  SC.connect(function () {
    console.log('made it');
  }
}

我的 sc-connect.html 页面如下所示:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  <html>
    <head>
      <title>Connect with SoundCloud</title>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    </head>
    <body onload="window.opener.setTimeout(window.opener.SC.connectCallback, 1)">
      <b style="width: 100%; text-align: center;">This popup should automatically close in a few seconds</b>
    </body>
  </html>

此应用程序在 soundcloud 上的重定向 URI:http://localhost:3000/sc-connect.html

4

3 回答 3

4

这实际上是 Chrome 中的一个奇怪错误,它是由从 Chrome App Store 安装 SoundCloud 应用程序引起的。很奇怪,我知道。

一种解决方法是代替使用window.opener,将 oauth 令牌推送到 LocalStorage 或 SessionStorage 并让打开器窗口侦听Storage 事件

于 2012-03-11T21:38:11.100 回答
0

看起来您的示例代码中缺少几个右括号。除此之外,您的示例似乎没有明显错误。我复制并粘贴了您的 sc-connect.html 并将其与以下内容一起使用:

<html>
<head>
  <title>Demo</title>
  <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js"></script>
  <script type="text/javascript" src="http://connect.soundcloud.com/sdk.js"></script>
  <script type="text/javascript">

  $(document).ready(function() {
      SC.initialize({
          client_id: 'MY_CLIENT_ID',
          redirect_uri: 'http://localhost:8080/connect/sc-callback.html'
      });

      $('button').click(function(){
          SC.connect(function() {
              SC.get('/me', function(data) {
                  $('#name').text(data.username);
              });
          });
      });
  });

  </script>
</head>
<body>
  <button>Connect</button>
  <p>
    Hello There, <span id="name"></span>
  </p>
</body>
</html>

这适用于 Firefox 和 Chrome。让我知道这是否有帮助。

于 2012-03-09T20:50:37.890 回答
0
    <!DOCTYPE html> <html lang="en"> 
<head> 
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
    <title>Connect with SoundCloud</title> 

</head>
<body onload="window.opener.setTimeout(window.opener.SC.connectCallback, 1)">
    <b style="text-align: center;">This popup should automatically close in a few seconds</b>
    <script type="text/javascript">window.opener.SC.connectCallback.call(this); </script> 
</body> 
</html> 
于 2016-07-22T10:40:13.740 回答