我有一个用 React Native 代码编写的应用程序。我有这个功能的组件:
handleLogin = async () => {
let redirectUrl = AuthSession.getRedirectUrl();
let results = await AuthSession.startAsync({
authUrl: `https://exampleurl.com/?uid=${CLIENT_ID}&redirect_uri=${encodeURIComponent(redirectUrl)}`
});
if (results.type !== 'success') {
this.setState({ didError: true });
} else {
if(results.params.token != undefined) {
let user = {
name: results.params.uname,
surname: results.params.surname,
token: results.params.token
}
this.setState({ userInfo: user});
this.props.loginUser(this.state.userInfo);
}
}
};
Run Code Online (Sandbox Code Playgroud)
问题是,当我在 Expo 中运行它们时,它运行良好,打开适当的 URL,我登录然后服务器成功返回我到 redirect_uri 和 app hide webapp modal 并显示我需要的内容。
但是,当我将应用程序导出到 android 并在我的手机中安装此 apk 时,它仍然可以正常工作,单击打开 webview,我以用户身份登录并返回。但它停留在“返回应用程序”步骤。它永远不会返回应用程序。我还在 app.json 中定义了架构:
{
"expo": {
"name": "MyNewApp",
"slug": "MyNewApp",
"privacy": "public",
"sdkVersion": "32.0.0",
"platforms": [
"ios",
"android"
],
"version": "1.0.0",
"orientation": "portrait",
"icon": "./assets/icon.png",
"splash": {
"image": "./assets/splash.png",
"resizeMode": "contain",
"backgroundColor": "#ffffff"
},
"scheme": "MyNewApp",
"updates": {
"fallbackToCacheTimeout": 0
},
"assetBundlePatterns": [
"**/*"
],
"ios": {
"bundleIdentifier": "com.roche.mynewapp",
"supportsTablet": true
},
"android": {
"package": "com.roche.mynewapp"
}
}
}
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?我尝试将重定向 uri 设置为encodeURIComponent('MyNewApp://')用作我定义的架构,但也没有成功。
in必须是你的scheme名字。app.jsonandroid.package
所以在你的情况下scheme: "com.roche.mynewapp"
这对我有用。有关更多详细信息,请参阅Expo 文档 https://docs.expo.io/versions/latest/sdk/app-auth/#appauthoauthredirect
| 归档时间: |
|
| 查看次数: |
1394 次 |
| 最近记录: |