高图中的jsonp回调数据不起作用

时间:2013-09-19 15:45:07

标签: node.js highcharts jsonp

使用nodejs和jsonp,试图找出高图但是它不起作用,beow code

<script type="text/javascript">
$(function () {
  $.getJSON('http://myserverhere.com:3010/?f=GBP&t=USD&callback=?', function (data) {
    alert("hey");
    console.log(data);
    // create the chart
    $('#container').highcharts('StockChart', {
      rangeSelector: {
        selected: 1
      },
      title: {
        text: 'AAPL Stock Price'
      },
      navigator: {
        enabled: true,
        height: 25
      },
      series: [{
        type: 'candlestick',
        name: 'AAPL Stock Price',
        data: data,
        dataGrouping: {}
      }]
    });
  });
});
</script>
下面的

是我在nodejs中的server.js

var http = require('http');
var url = require('url');
var fs = require('fs');
var port = 3010;
var path = "C:\\mypath\\";
http.createServer(function (req, res) {
  if (req.url === '/favicon.ico') {
    res.writeHead(200, {
      'Content-Type': 'image/x-icon'
    });
    return res.end();
  }
  var query = url.parse(req.url, true).query;
  var urlString = {
    pathname: url.parse(req.url).pathname,
    queryparam: url.parse(req.url, true).query
  };
  var file = query.f + query.t;
  var gbpusd;
  fs.readFile(path + file + '_M1.json', function (err, data) {
    if (err) {
      console.log(err);
    }
    //console.log(data);
    gbpusd = JSON.parse(data);
    console.log("query param");
    console.log(urlString.queryparam.callback);
    if (urlString.queryparam.callback && urlString.queryparam.callback != '?') {
      console.log("in if block");
      gbpusd = urlString.queryparam.callback + "(" + gbpusd + ");";
    }
    //console.log(eurusd);
    res.writeHead(200, {
      'content-type': 'application/json',
      'content-lenght': gbpusd.length
    });
    //res.write(JSON.stringify(gbpusd));
    var p = JSON.stringify(gbpusd);
    res.end(p);
  });
}).listen(port);
console.log("server running at port 3010..");

它是一个简单的高图烛台,我正在尝试使用我的jsonp数据。 控制台记录数据以及成功返回jsonp功能,但在高图回调它不工作,甚至警报没有运行。 我可以闻到节点res.end()或节点返回数据的方式有问题,不知道但只是一个计算的猜测。 任何一个请。

1 个答案:

答案 0 :(得分:0)

好吧我终于解决了,这是stringify的放置是错误的,数据应该在它被包装在jsonp调用之前先进行字符串化,即在调用之前,这是有意义的,否则回调函数将被字符串化。那是错误,我的代码破了

if(urlString.queryparam.callback && urlString.queryparam.callback != '?'){
        console.log("in if block");
        gbpusd = urlString.queryparam.callback + "(" + gbpusd + ");";       
    }

首先我使用JSON.parse()解析数据,然后使用stringify。 var parseddata = JSON.parse(data); gbpusd = JSON.stringify(parseddata);