我正在开发一个使用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的解决方案,并测试了其他浏览器,但它对我没用。我做错了什么?
答案 0 :(得分:3)
您在快速回复中发送的重定向被您在前端使用的http客户端捕获,并且重定向发生在那里。您处于经典的CORS状态,当然这不是您可以与Twitter其他API进行交互的方式。
您必须在节点端(服务器到服务器)对Twitter进行http调用,或者使用Twitter的客户端客户端库(https://dev.twitter.com/web/javascript)