这个错误通常发生在使用 OAuth2 认证流程时,我們需要通过设置 redirect_uri 参数来指定获得用户授权后重定向的 URL。如果设置的 redirect_uri 与在 GitHub 上注册应用程序时提供的回调 URL 不匹配,就会出现这个错误。
以下是解决方法,以 Flask 应用为例:
在 GitHub 上注册一个 OAuth 应用程序,并指定回调 URL。
在 Flask 应用程序中配置 Authlib,并将回调 URL 设置为注册的 GitHub 回调 URL:
from authlib.integrations.flask_client import OAuth
oauth = OAuth()
oauth.register(
name='github',
client_id='your-github-client-id',
client_secret='your-github-client-secret',
access_token_url='https://github.com/login/oauth/access_token',
authorize_url='https://github.com/login/oauth/authorize',
api_base_url='https://api.github.com/',
client_kwargs={'scope': 'user:email'},
redirect_uri='https://your-callback-url.com'
)
确保 redirect_uri 与 GitHub 上注册的回调 URL 一致。
在使用 OAuth2 认证流程时,传递 redirect_uri 参数的值与在注册时指定的回调 URL 相同:
def authorize():
redirect_uri = 'https://your-callback-url.com'
return oauth.github.authorize_redirect(redirect_uri)
这样就可以避免出现“redirect_uri 必须与注册的回调匹配”的错误了。