不从身份验证代码返回刷新令牌

时间:2018-10-09 18:55:43

标签: node.js oauth google-authentication google-apis-explorer refresh-token

我正在使用来自节点的googleapis包来获取刷新令牌,并从前端传递的身份验证代码访问令牌,但是每次遇到以下错误时。

  {      
      error: 'redirect_uri_mismatch',
      error_description: 'Bad Request' 
  }

我知道当我们不匹配在控制台中作为回调URL传递的URL时出现此错误。     https://console.cloud.google.com/apis/credentials

但是我已经在控制台中设置了正确的URL。仍然不确定代码有什么问题。

使用/auth将令牌从front-end传递到node-server

const {
    google
} = require("googleapis");
const OAuth2 = google.auth.OAuth2;
var bodyParser = require('body-parser')

const express = require('express');
const app = express();
app.use(bodyParser.json());

app.use(function (req, res, next) {
    res.header("Access-Control-Allow-Origin", "*");
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
    next();
});


app.use('/tokenCallback', (req, res) => {
    console.log(req);
    res.send('An alligator approaches!');
});

app.post('/auth', (req, res) => {
    runProcess(req.body.auth);
    res.send('An alligator approaches!');
});

app.listen(4300);

function runProcess(code) {

    const oauth2client = new OAuth2(
        "210347756664-xxxxxxxxxxxxxxxxxxxxx.apps.googleusercontent.com",
        "57ZU6JuQ7oQ7SvSFtki5atxx", // Client Secret
        "http://localhost:4300/tokenCallback",
    );

    oauth2client.getToken(code, (e) => {
        console.log(e);
    });

    oauth2client.on('tokens', (tokens) => {
        if (tokens.refresh_token) {
            console.log("refresh token", tokens);
        }
    });

}

任何人的帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

redirect_uri_mismatch表示您的应用程序未发送有效的重定向URI,或者未在Google Cloud Console上注册。

确保在Console -> APIs & Services -> Credentials -> OAuth client IDs -> (your key)中添加了http://localhost:4300/tokenCallback URI。