1

サーバーのポート 8080 で実行されているサービスから JSON オブジェクトを取得しようとしています。これを実現するために、次の JavaScript および PHP コードを実装しました。

JavaScript:

$.ajax({
    type: 'GET',
    url: "mediainfo.php?file="+stream_,
    dataType: 'json',
    success: play,
    error: function( xhr, reply ) {
       play({});
    }
});

mediainfo.php:

<?php
    $url = "http://localhost:8080/media_info/" . $_GET['file'];
    echo file_get_contents($url);

ただし、Ajax 呼び出しが成功した場合でも、コールバックは呼び出されません。奇妙なことに、失敗した場合 (たとえば、$url が有効な JSON を返さない場合)、コールバックが呼び出されます。

何が問題なのかわかりません。どんな助けでも大歓迎です。

編集:

コールバック関数:

var play = function( info ) {
     if ( info.width && info.height ) {
         while ( info.width < 640 ) {
             info.width = Math.round( info.width * 1.5 );
             info.height = Math.round( info.height * 1.5 );
         }
         while( info.width > 1024 ) {
             info.width = Math.round( info.width / 2 );
             info.height = Math.round( info.height / 2 );
         }
     }

     var width = info && info.width || 640;
     var height = info && info.height || 480;
     var flashvars = {
         file : stream,
         streamer : "rtmp://myserver.com:1935/vodplayback",
         'rtmp.tunneling' : false,
         bufferlength : 5,
         autostart : true
     };
     var paramObj = {allowfullscreen : "true", allowscriptaccess : "always"};
     swfobject.embedSWF("http://myserver.com:8080/flu/jwplayer.swf", "videoplayer", width, height, "10.3", false, flashvars, paramObj, {id : "jwplayer", name : "jwplayer"});
  }

mediinfo.php からの応答:

{"duration":69960.0,"width":720,"height":406} 
4

2 に答える 2

1

したがって、Ajax 呼び出しでは関数宣言の順序が重要であることがわかります。誰が知っていましたか^^

Ajax 呼び出しの後にコールバック関数を定義しました。それらを切り替えたところ、正常に動作するようになりました。

回答ありがとうございます。

于 2013-08-09T02:26:16.773 に答える
0
$.ajax({
    url: 'test.php',
    dataType: 'html',
    data: { test: 'test' },
    type: 'GET',
    success: function( data ) {
        console.log( 'success' );
        $( '#div2' ).html( data );
    },
    error: function( xhr ) {
        console.log( xhr.status );
    }

});

またはこのように

<?php
$url = "http://localhost:8080/media_info/" . $_GET['file'];
echo json_encode( Array(
    'data': file_get_contents( $url )
) );
?>

JavaScript

$.ajax({
    url: 'test.php',
    dataType: 'json',
    data: { file: stream_ },
    type: 'GET',
    success: function( callback) {
        console.log( 'success' );
        $( '#div2' ).html( callback.data );
    },
    error: function( xhr ) {
        console.log( xhr.status );
    }

});
于 2013-08-09T01:57:43.970 に答える