wlh*_*wlh 0 node.js cors passport-twitter passport.js create-react-app
我正在我的create-react-app应用程序上设置 Twitter oauth ,方法是axios在前端使用辅助函数(via )passport在我的后端启动oauth 过程。我目前正在开发中,所以我在端口上托管我的快速服务器,在端口上托管我的3001前端,前端3000有一个代理到端口3001.我已经通过corsnpm 包设置了 CORS 权限。
无论我尝试哪种配置,我都无法完成 Twitter OAuth 流程。我试过切换端口,保持相同的端口;我试过用express-http-proxy.
我在回调函数和初始 api 调用中都使用了http://127.0.0.1而不是localhost,尝试了端口3000和3001.
我现在不确定我哪里出错了,或者我是否需要放弃passport-twitter其他解决方案。
在每种情况下,我都会收到以下错误:
Failed to load https://api.twitter.com/oauth/authenticate?
oauth_token=alphanumericcoderedactedherebyme: No 'Access-Control-Allow-Origin'
header is present on the requested resource. Origin 'http://localhost:3000' is
therefore not allowed access.
Run Code Online (Sandbox Code Playgroud)
根据我尝试的配置,我将 origin 设为nullorhttp://localhost:3001或http://127.0.0.1。
请注意,由于其他原因,例如连接到Yelp Fusion API. 此外,我使用中间件来记录我的会话数据,我可以看到我成功地获取oauth_token和oauth_token_secret来自 Twitter。呼叫在 oauth 过程的下一段失败:
[0] *************SESSION MIDDLEWARE***************
[0] Session {
[0] cookie:
[0] { path: '/',
[0] _expires: 2018-01-06T20:20:31.913Z,
[0] originalMaxAge: 2678400000,
[0] httpOnly: true },
[0] 'oauth:twitter':
[0] { oauth_token: 'alphanumericcoderedactedherebyme',
[0] oauth_token_secret: 'alphanumericcoderedactedherebyme' } }
[0]
[0] Logged In:
[0] __________ false
[0] **********************************************
Run Code Online (Sandbox Code Playgroud)
这是我的代码的相关部分 -
后端代码
服务端JS
// Dependencies
const express = require("express");
const cors = require("cors");
const passport = require('passport');
// Initialize Express Server
const app = express();
// Specify the port.
var port = process.env.PORT || 3001;
app.set('port', port);
app.use(passport.initialize());
app.use(passport.session());
//enable CORS
app.use(cors());
//set up passport for user authentication
const passportConfig = require('./config/passport');
require("./controllers/auth-controller.js")(app);
// Listen on port 3000 or assigned port
const server = app.listen(app.get('port'), function() {
console.log(`App running on ${app.get('port')}`);
});
Run Code Online (Sandbox Code Playgroud)
护照.JS
const passport = require('passport');
const TwitterStrategy = require('passport-twitter').Strategy;
passport.use(new TwitterStrategy({
consumerKey: process.env.TWITTER_CONSUMER_KEY,
consumerSecret: process.env.TWITTER_CONSUMER_SECRET,
callbackURL: process.env.NODE_ENV === 'production' ? process.env.TWITTER_CALLBACK_URL : 'http://localhost:3000/auth/twitter/callback'
},
function(accessToken, refreshToken, profile, done) {
...etc, etc, etc
Run Code Online (Sandbox Code Playgroud)
授权控制器.JS
const router = require('express').Router();
const passport = require('passport');
module.exports = function(app) {
router.get('/twitter', passport.authenticate('twitter'));
router.get('/twitter/callback',
passport.authenticate('twitter', {
successRedirect: '/auth/twittersuccess',
failureRedirect: '/auth/twitterfail'
})
);
router.get('/twittersuccess', function(req, res) {
// Successful authentication
res.json({ user: req.user, isAuth: true });
})
router.get('/twitterfail', function(req, res) {
res.statusCode = 503;
res.json({ err: 'Unable to Validate User Credentials' })
})
app.use('/auth', router);
}
Run Code Online (Sandbox Code Playgroud)
前端代码
帮助器.JS
import axios from 'axios';
export function authUser() {
return new Promise((resolve, reject) => {
axios.get('/auth/twitter', {
proxy: {
host: '127.0.0.1',
port: 3001
}
}).then(response => {
resolve(response.data);
}).catch(err => {
console.error({ twitterAuthErr: err })
if (err) reject(err);
else reject({ title: 'Error', message: 'Service Unavailable - Please try again later.' });
});
});
}
Run Code Online (Sandbox Code Playgroud)
这意味着问题在于在与我的后端不同的端口上使用 Create-React-App。
http://127.0.0.1:3001/auth/twittersuccess
"user": {
"_id": "redactedbyme",
"name": "Wesley L Handy",
"__v": 0,
"twitterId": "redactedbyme",
"favorites": [],
"friends": []
},
"isAuth": true
Run Code Online (Sandbox Code Playgroud)
在咨询了几位开发人员并在其他论坛上发布了这个问题后,我找不到手头问题的解决方案。
但是,根据此博客,passport-twitter未针对 RESTful api 进行优化。同一篇博客提供了使用此 passport-twitter-token策略的有用教程,并react-twitter-auth在此处找到
该问题与使用 Create-React-App 的应用程序在两台不同的服务器上运行有关,一台用于前端,另一台用于后端。如果没有前端和后端之间的一系列通信,就无法解决 CORS 问题,这是护照所不允许的。Passport 是用于在单服务器上处理 OAuth 的绝佳工具,但 OAuth 需要相当多的来回操作,这需要更多的复杂性。
Ivan Vasiljevic的教程是理解和解决这种复杂性的有用起点。
| 归档时间: |
|
| 查看次数: |
1145 次 |
| 最近记录: |