gpt4 book ai didi

javascript - Axios CORS 问题与 Github oauth 未获取访问 token

转载 作者:行者123 更新时间:2023-12-03 03:25:00 25 4
gpt4 key购买 nike

我在我的 React-Redux 应用程序上创建了 2 条路由。我已经添加了带有主页和回调 URL 的 github 应用程序设置。

1.当您选择这条路线时:https://reduxapp.herokuapp.com/signin您点击 Github 登录按钮,==> githubGeturi

2.Github 使用代码 https://reduxapp.herokuapp.com/auth/callback?code=9536286a59228e7784a1 重定向回来并触发 githubSendCode('9536286a59228e7784a1') 操作

您可以在网络调用 OPTIONS 中看到调用通过,但 POST 调用从未发生。然后您会收到控制台错误:

XMLHttpRequest cannot load https://github.com/login/oauth/access_token?client_id=32b70bf671e04762b26c&…_secret=123456789123456789123456789&code=9536286a59228e7784a1. Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'https://reduxapp.herokuapp.com' is therefore not allowed access.

以下是我的操作函数:

const CLIENT_ID = '32b70bf671e04762b26c';
const CLIENT_SECRET = '123456789123456789123456789';
const ROOT_URL = window.location.origin;
const REDIRECT_URL = `${ROOT_URL}/auth/callback`;
const AUTHORIZE_URL = 'https://github.com/login/oauth/authorize';
const ACCESS_TOKEN_URL = 'https://github.com/login/oauth/access_token';
const STATE = _.random(10000);

export function githubGeturi() {
const GITHUB_URL = `${AUTHORIZE_URL}?client_id=${CLIENT_ID}&scope=user,public_repo&redirect_uri=${REDIRECT_URL}`;

return (dispatch) => dispatch(signinUrl(GITHUB_URL));
}

export function githubSendCode(code) {
const GITHUB_URL = `${ACCESS_TOKEN_URL}?client_id=${CLIENT_ID}&client_secret=${CLIENT_SECRET}&code=${code}`;

axios.defaults.headers.post['Access-Control-Allow-Origin'] = '*';
const axiosPost = axios.post(
GITHUB_URL,
{
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Accept': 'text/json'
}
});

return (dispatch) => {
dispatch(signinRequest());
return axiosPost
.then(
success => dispatch(signinSuccess(success)),
error => dispatch(signinError(error))
);
};
}

========我发现唯一可能的方法是与服务器进行 POST 调用。您可以在此处查看整个解决方案:https://github.com/steelx/ReduxWeatherApp/commit/6215634ca543a4760ea96397fe31b61f22184d91

最佳答案

您似乎无法通过 JavaScript 调用该端点

https://github.com/isaacs/github/issues/330

在您的示例中,我看到 OPTIONS 方法调用失败,这是因为 axios 在您向请求添加额外 header 时会执行此操作,但 POST 调用也会失败。

您可以在您的应用程序和服务器上的 github 之间设置一个代理,该代理只需转发您的请求并回复响应。

关于javascript - Axios CORS 问题与 Github oauth 未获取访问 token ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36907693/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com