角度与hapi js服务器jsonp

时间:2015-08-12 07:50:06

标签: javascript json angularjs jsonp hapijs

我在/api/profile定义了一个接受帖子参数的端点。

var http = require('http');
var serverConfig = require('../server.config.js');
var request = require('request');


module.exports = function(server){
  server.route({
      method: 'POST',
      path: '/api/profile',
      handler: getProfileData
  });


    function getProfileData(request, reply){
        var battleTag = request.payload.battleTag;
        getProfileDataHttp(battleTag, function(err, data){
            if(err){
                reply(new Error(err));
            }
            reply(data);
        });
    }

    function getProfileDataHttp(battleTag, callback){
        var key = serverConfig.battleNet.apiKey;
        var tag =  encodeURIComponent(battleTag);
        var url = 'https://eu.api.battle.net/d3/profile/'+ tag + '/?locale=en_GB&callback=JSON_CALLBACK&apikey=' + key;
        console.log(url);
        request(url,function(error, response, body){
            if(error){
                callback(err);
            }

            if(!error && response.statusCode ==200){
                callback(null, body);
            }
        });
    }
};

它正在使用json回调调用api,当我收到格式时的数据时:

JSON_CALLBACK({ json data here})

如何让这个端点只返回json数据,我试过JSON.parse(),但它会导致服务器出错。

调用此端点的角度服务如下所示:

 function getProfileData(battleTag){
            var defer = $q.defer();

            var tag = validTag(battleTag);
            if(!tag){
                defer.reject('Invalid Tag please use format 1[a-z]11[a-z0-9]#4[0-9]');  
                return defer.promise;             
            }

            $http.post('/api/profile', {
                    battleTag: battleTag
                })
               .success(function(data){
                    if(data.reason){
                        defer.resolve(data.reason);
                    }
                    defer.resolve(data);               
                })
                .error(function(err){
                    defer.reject(err);
                });

            return defer.promise;
        }

在角度使用$ http.jsonp时调用会起作用但是我必须创建服务器来隐藏客户端的密钥

1 个答案:

答案 0 :(得分:0)

你的问题有点令人困惑。您正在谈论JSONP,但您想直接获取数据。

JSONP的重点是返回封装在您选择的函数内的数据。然后你只需要执行它。

如果您想直接获取数据,请不要使用JSONP。只需做一个正常的"调用

快速查看Battle.net API后,似乎要直接获取数据,您应该省略'回调'您请求的网址中的参数。

因此,您的请求网址如下:

var url = 'https://eu.api.battle.net/d3/profile/'+ tag + '/?locale=en_GB&apikey=' + key;