原因'http:// localhost:3000'因此不允许访问Twitter API

时间:2017-08-29 17:19:23

标签: javascript angularjs node.js web twitter

我正在开发一个使用Twitter API REST的网络应用程序。我有一个包含Twitter帐户的页面和一个用于添加新帐户的按钮。按下按钮时,将执行Angular控制器中的功能:

// Calls token to add a new Twitter user
    $scope.callToken = function () {
        $http.get('/token')
            .then(function (response) {
                console.log(response);
            });
    };

这是后端服务de request的代码。它只是重定向到Twitter以添加新用户。

// routes.js
var token = express.Router();

	token.route('/token')
		.get(cuentasCtrl.getToken);
    
// Account file

exports.getToken = function(req, res) {

	twitter.getRequestToken(function(err, requestToken, requestSecret) {
        if (err)
            res.status(500).send(err);
        else {
            _requestSecret = requestSecret;
            res.setHeader('Access-Control-Allow-Origin', '*');
            res.redirect("https://api.twitter.com/oauth/authenticate?oauth_token=" + requestToken);
        }
    });
};

但我得到了下一个错误:

Origin 'http://localhost:3000' is therefore not allowed access Twitter API

我的服务器在localhost:3000上运行,如果我在我的浏览器中放置localhost:3000 / token,则没有问题。我已经阅读了using CORS的解决方案,并测试了其他浏览器,但它对我没用。我做错了什么?

1 个答案:

答案 0 :(得分:3)

您在快速回复中发送的重定向被您在前端使用的http客户端捕获,并且重定向发生在那里。您处于经典的CORS状态,当然这不是您可以与Twitter其他API进行交互的方式。

您必须在节点端(服务器到服务器)对Twitter进行http调用,或者使用Twitter的客户端客户端库(https://dev.twitter.com/web/javascript