WebView控制器Android

问题描述 投票:0回答:3

我正在努力 WebView. 不知道能不能做到。我在这个视图里面打开一个url,基本上就是一个登录页面。现在想获取用户是否成功登录的信息。如果是,那么导航到自定义页面(安卓原生)否则继续在该页面上。

先谢谢你。

android webview android-webview
3个回答
1
投票

我们可以通过使用这个来实现。

  1. 在HTML页面的Login SuccessFailue HtmL页面中创建一个javascript函数。
  2. 在这个javascript函数中,使用addJavascriptInterface调用你的本地函数。
 package com.example.androidjsdemo;

 import java.io.File;

import android.support.v7.app.ActionBarActivity;
import android.content.Context;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.webkit.JavascriptInterface;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Toast;

 public class MainActivity extends ActionBarActivity {


public class WebAppInterface {
    Context mContext;

    /** Instantiate the interface and set the context */
    WebAppInterface(Context c) {
        mContext = c;
    }

    /** Show a toast from the web page */
    @JavascriptInterface
    public void showToast(String toast) {
        Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
        // Here you can Start WhatEver Activty launch///////
    }
}

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    WebView webMy = (WebView) findViewById(R.id.webMy);
    webMy.addJavascriptInterface(new WebAppInterface(this), "Android");
    WebSettings setting = webMy.getSettings();
    setting.setJavaScriptEnabled(true);
    //File file = new File("andoid");
    webMy.loadUrl("file:///android_asset/mine.html");
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    if (id == R.id.action_settings) {
        return true;
    }
    return super.onOptionsItemSelected(item);
}
}

 mine.html


<HTML>
<script>
function called()
{
  // alert("hi");
  Android.showToast("Hi Testing");
}
</script>
<Body>
Hi Sumit
<button onclick="called()">click me</button>
</Body>
</HTML>

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
 android:layout_height="match_parent"

 tools:context="com.example.androidjsdemo.MainActivity" >

 <WebView
    android:id="@+id/webMy"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
     />

 </RelativeLayout>

0
投票

当用户完成了成功的演唱后,他应该重定向到其他网页,并在网页上显示登录成功的网址。http://www.yourwebsite.com/islogin?yes.比你需要做的是在你的应用程序中检查登录状态,通过验证网址包含 islogin 并将其设置为 yes 并做任何你想要的。

这里有一个小例子来帮助你开始。

webView.getSettings().setJavaScriptEnabled(true);
webView.setWebViewClient(new WebViewClient() {

        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            if(isUserLoggedIn(url)){
                doWork();
                return true;
            } else {
                return false;
            }
        }

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

        public void onPageFinished(WebView view, String url) {
        }
    });

0
投票

例如,下面是你的登录网址,你加载在webview登录

String loginURL = "http://www.myurl.com/login";

有两种可能,当用户点击登录按钮时

1)成功

按照网页代码导航到其他页面。所以我们需要检查一下,打开我们的原生应用界面。

2)失败

同样的登录页面,但根据用户的输入显示错误信息。

webView.setWebViewClient(new WebViewClient() {

            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                if (url.contains(loginURL)) {
                    // Login Fail
                    return false;
                } else {
                    // Login Success 
                    // Open Android Native screen
                    return true;
                }
            }
        });
© www.soinside.com 2019 - 2024. All rights reserved.