使用Javascript在webview(安卓系统)中填写表单,无需输入类型为文本和密码的元素ID

Using Javascript to fill form in webview(Android) without element ID of input type- text and password?

本文关键字:类型 输入 文本 ID 元素 密码 表单 webview Javascript 系统 使用      更新时间:2023-09-26

我已经在我的应用程序的webview中打开了一个网站(Cyberoam学院)的登录页面。现在我想让用户不必一次又一次地输入用户名和密码,而是可以从列表或其他地方选择,应用程序会自动填写用户名、密码并点击登录。我已经读到,要做到这一点,我需要在我的webview中实现javascript。

问题是,用户名和密码字段的html标签中都没有id,只有name属性-

<input type="text" name="username">
<input type="password" name="password">

登录按钮有ID,因此可以使用-

<input type="submit" name="btnSubmit" value="Login" id="logincaption">

现在,我需要以某种方式使用MainActivity.java中存储在变量中的字符串来填充用户名textField,然后是密码字段,最后在用户单击存储用户名和密码列表中的元素时单击登录按钮。

请告诉我如何在Android中实现这一点!

首先,使用以下语句

@SuppressLint("SetJavaScriptEnabled")

然后,你可以:

mWebView = (WebView) findViewById(R.id.webview); 
mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.setWebChromeClient(new WebChromeClient());
mWebView.setWebViewClient(new WebViewClient(){
    @Override
    public void onPageFinished(WebView view, String url) {
        String javascript="javascript: document.getElementById('someid').innerHTML='Hello World!';";
        view.loadUrl(javascript);
    }
});
mWebView.loadUrl(URL);

您可以使用此方法插入Java接口,以通过Java方法异步控制。

首先要确保这不是iframe。我相信,如果您可以构建本地登录,那么就没有理由添加webView用于登录。无论如何,如果你需要选择输入,你可以使用:

  function login(){
        document.querySelector("input[name=username]").value  = "username";
        document.querySelector("input[name= password]").value  = "password";
        document.forms[0].submit();
 }

要将Java代码中的值传递给JS,必须编写一个桥接器并触发JS函数你可以在这里阅读如何建造桥梁:http://blog.cuelogic.co.in/simple-android-java-javascript-bridge/