Android WebView无法加载Instagram授权

问题描述 投票:1回答:1

我目前正在尝试学习如何使用Instagram api授权Instagram帐户并在我的应用程序中获取基本信息。

我正在使用简单的WebView加载授权URL。但是当我按下按钮加载WebView时,它会在webview中显示instagram登录页面:https://i.imgur.com/rM9NBYJ.jpg,而不是授权页面,它应该看起来像https://i.imgur.com/ez80umn.jpg

当我将它插入我的Chrome浏览器时(这是我获取屏幕截图的方式)但链接工作正常,但不在WebView中。

如何让它显示授权页面?

public class MainActivity extends AppCompatActivity {
private WebView webView;
Button loginButton;
String url = "https://api.instagram.com/oauth/authorize/?client_id=" +
        "xxxxxxxxxxx&redirect_uri=https://www.google.com/&response_type=code";
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    webView = findViewById(R.id.webView);
    loginButton = findViewById(R.id.instagramButton);

    WebSettings settings = webView.getSettings();
    settings.setJavaScriptEnabled(true);
    loginButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            initializeWebView();
        }
    });
}
private void initializeWebView(){

     webView.loadUrl(url);
     webView.setWebViewClient(new WebViewClient(){
         String access_token;
         boolean authComplete;

         @Override
         public void onPageStarted(WebView view, String url, Bitmap favicon) {
             super.onPageStarted(view, url, favicon);
         }

         @Override
         public void onPageFinished(WebView view, String url) {
             super.onPageFinished(view, url);
             if (url.contains("#access_token=") && !authComplete) {
                 Uri uri = Uri.parse(url);
                 access_token = uri.getEncodedFragment();
                 access_token = access_token.substring(access_token.lastIndexOf("=") + 1);
                 Log.e("access_token", access_token);
                 authComplete = true;
             } else if (url.contains("?error")) {
                 Log.e("access_token", "errir fetching access token");
             }
         }
     });
}
}

(是的,我用正确的客户端ID替换网址中的x)

activity_main.xml中:

<?xml version="1.0" encoding="utf-8"?>
<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">
<WebView
    android:id="@+id/webView"
    android:layout_width="match_parent"
    android:layout_height="300dp">
</WebView>
<Button
    android:id="@+id/instagramButton"
    android:layout_below="@id/webView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    android:text="Instagram login"/>

</RelativeLayout>
java api authorization instagram instagram-api
1个回答
-1
投票

我有点晚了,但是对于其他可能遇到这个问题的人来说:

WebSettings settings = wv.getSettings();
settings.setJavaScriptEnabled(true);
settings.setDomStorageEnabled(true);

有了这个,我的Instagram登录显示正常。

关于你发布的两张图片,我看到第一张是因为你没有登录,而第二张是因为你已经登录而要求你授权你的帐户。所以,只需输入你的电子邮件和密码( ?)。

© www.soinside.com 2019 - 2024. All rights reserved.