oauth-2.0 通过Android Webview进行不一致OAuth2登录失败

von4xj4u  于 2022-10-31  发布在  Android
关注(0)|答案(2)|浏览(215)

我使用discord让用户登录我的android应用程序。代码如下:
MainActivity.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">
<FrameLayout
        android:id="@+id/webview_frame"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MyActivity">
    <WebView
            android:id="@+id/authWebView"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:visibility="invisible"
            app:layout_anchorGravity="center" />
</FrameLayout>

DiscordOAuth.java:

package com.example.oauth2test;

import android.app.Activity;
import android.view.View;
import android.webkit.CookieManager;
import android.webkit.WebView;
import android.webkit.WebViewClient;

class DiscordOAuth {
    private static final String LOG_TAG = "Discord OAuth 2 Login";

    public void getAuthentication(Activity activity) {

        String authURL = "https://discordapp.com/login";

        WebView authWebView = activity.findViewById(R.id.authWebView);
        authWebView.getSettings().setJavaScriptEnabled(true); // enable javascript
        authWebView.getSettings().setAppCacheEnabled(true);
        authWebView.getSettings().setLoadWithOverviewMode(true);
        authWebView.getSettings().setUseWideViewPort(true);
        authWebView.getSettings().setBuiltInZoomControls(true);
        authWebView.getSettings().setSupportMultipleWindows(true);
        authWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
        CookieManager cookieManager = CookieManager.getInstance();
        cookieManager.setAcceptCookie(true);
        authWebView.setWebViewClient(new WebViewClient());

        authWebView.loadUrl(authURL);
        authWebView.setVisibility(View.VISIBLE);
    }
}

当执行上述操作时,您将得到一个登录页面,但当您尝试登录时,加载动画将出现片刻,您将返回登录页面,甚至没有成功或失败
查找后,我怀疑问题与多个窗口和如何处理有关,但我不能确定。
最终目标是通过WebView使用oauth2登录到discord并获取用户的用户名

km0tfn4u

km0tfn4u1#

在类中实现AuthCallback接口&您将在回调方法中获得响应

3htmauhk

3htmauhk2#

Discord内部需要WSS连接才能完成授权。WSS连接需要DOM存储来存储客户端信息。但在Android webview中,默认情况下禁用DOM存储。您可以通过webSettings.domStorageEnabled = true在WebSettings中更改此设置

相关问题