Android使用Html实现登录功能——重点掌握Webview js的使用

本文介绍如何利用WebView实现在Android应用内加载H5登录页面,并实现与原生应用的交互,包括JavaScript接口调用、加载进度显示及链接处理。

转载自:http://blog.youkuaiyun.com/qq_25193681/article/details/52117281

大家好,很久没有写博客了,因为工作需要,项目需要转换成H5的形式,所以闭关修炼html,所以可能在未来的几篇博客,我都会涉及到这类的知识,我不会太多的涉及到理论,更多的是实际的代码,下面就开始这次需求的实现,先看看主要界面。

这里写图片描述

这就是主要的效果了,代码不多,很容易理解的,这里主要通过webview,用js实现交互。 
首先看看webview里面常用的方法:

如何创建WebView: 
1、添加权限:AndroidManifest.xml中必须使用许可”android.permission.INTERNET”,否则会出Web page not available错误。 
2、在要Activity中生成一个WebView组件:WebView webView = new WebView(this); 
3、设置WebView基本信息: 
如果访问的页面中有Javascript,则webview必须设置支持Javascript。

      webview.getSettings().setJavaScriptEnabled(true); 
      触摸焦点起作用
      webview.requestFocus();//如果不设置,则在点击网页文本输入框时,不能弹出软键盘及不响应其他的一些事件。

4、设置WevView要显示的网页:
      互联网用:webView.loadUrl("http://www.google.com");
      本地文件用:webView.loadUrl("file:///android_asset/XX.html");  本地文件存放在:assets文件中

5、如果希望点击链接由自己处理,而不是新开Android的系统browser中响应该链接。
      给WebView添加一个事件监听对象(WebViewClient)     
      并重写其中的一些方法

 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

shouldOverrideUrlLoading:对网页中超链接按钮的响应。当按下某个连接时WebViewClient会调用这个方法,并传递参数:按下的url 
onLoadResource 
onPageStart 
onPageFinish 
onReceiveError 
onReceivedHttpAuthRequest

 6.listview,webview中滚动拖动到顶部或者底部时的阴影(滑动到项部或底部不固定)
       WebView.setOverScrollMode(View.OVER_SCROLL_NEVER);

7.//android 中 webview 使用 localStorage

 
  • 1
  • 2
  • 3
  • 4
  • 5

WebSettings settings = mWebView.getSettings(); 
// 设置可以使用localStorage 
settings.setDomStorageEnabled(true); 
// 应用可以有数据库 
settings.setDatabaseEnabled(true); 
String dbPath = this.getApplicationContext().getDir(“database”, Context.MODE_PRIVATE).getPath(); 
settings.setDatabasePath(dbPath); 
// 应用可以有缓存 
settings.setAppCacheEnabled(true); 
String appCaceDir = this.getApplicationContext().getDir(“cache”, Context.MODE_PRIVATE).getPath(); 
settings.setAppCachePath(appCaceDir); 
8、如果用webview点链接看了很多页以后,如果不做任何处理,点击系统“Back”键,整个浏览器会调用finish()而结束自身,如果希望浏览的网页回退而不是退出浏览器,需要在当前Activity中处理并消费掉该Back事件。 
覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法。

    public boolean onKeyDown(int keyCoder,KeyEvent event){
                        if(webView.canGoBack() && keyCoder == KeyEvent.KEYCODE_BACK){
                              webview.goBack();   //goBack()表示返回webView的上一页面
                                 return true;
                           }
                        return false;
                   }
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

WebView相关问题注意:

Android的webView很强大,其实就是一个浏览器,你可以把它嵌入到你想要的位置,我这里遇到两个问题,就是怎么知道网页的加载进度和加载网页时,点击网页里面的链接还是在当前的webview里跳转,不想跳到浏览器那边,解决办法如下:

//此方法可以处理webview 在加载时和加载完成时一些操作
webView.setWebChromeClient(new WebChromeClient(){
  @Override
  public void onProgressChanged(WebView view, int newProgress) {
    if(newProgress==100){                      
      // 这里是设置activity的标题, 也可以根据自己的需求做一些其他的操作
          title.setText("加载完成");
     }else{
     title.setText("加载中.......");
      }
    }
});
webView.setWebViewClient(new WebViewClient(){

  @Override

    public boolean shouldOverrideUrlLoading(WebView view, String url) { 
     //重写此方法表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边
       view.loadUrl(url);
       return true;
  }

 @Override
public void onReceivedSslError(WebView view, SslErrorHandler handler, android.net.http.SslError error) { 
// 重写此方法可以让webview处理https请求
        handler.proceed();
} 
});
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

介绍完Webview,就可以开始我们今天的编码了;

首先先把布局写好:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/text"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#458EFD"
        android:gravity="center"
        android:padding="10dip"
        android:textColor="#ffffff"
        android:textSize="24sp" />

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

</LinearLayout>

 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

布局不是很复杂,就是标题和webview。

接下来看到MainActivity.java

public class MainActivity extends Activity{
    WebView view;
    JavaScriptObject js;
    TextView titleTv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_main);
        view=(WebView) findViewById(R.id.web);
        titleTv=(TextView) findViewById(R.id.text);
        js=new JavaScriptObject(this);
        view.getSettings().setDefaultTextEncodingName("utf-8");  
        view.getSettings().setJavaScriptEnabled(true);  
        view.addJavascriptInterface(js, "myObj");
        view.loadUrl("file:///android_asset/demo.html");
        view.setWebViewClient(new WebViewClient() {
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
            // 出现错误是   的回调
            @Override
            public void onReceivedError(WebView view, int errorCode,
                    String description, String failingUrl) {
                // TODO Auto-generated method stub
                super.onReceivedError(view, errorCode, description, failingUrl);
            }
        });
        view.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onReceivedTitle(WebView view, String title) {
                // 设置标题
                super.onReceivedTitle(view, title);
                if (titleTv != null) {
                    titleTv.setText(title);
                }
            }

            @Override
            public void onShowCustomView(View view, CustomViewCallback callback) {
                // TODO Auto-generated method stub
                super.onShowCustomView(view, callback);
            }

        });

    }


}
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52

具体的方法介绍,在前面也介绍过了,就不再赘述,值得注意的是,我这里还添加了一个js——JavaScriptObject。

public class JavaScriptObject {  
    Context mContxt;  
    public JavaScriptObject(Context mContxt) {  
        this.mContxt = mContxt;  
    }  
    @JavascriptInterface
    public void fun2(String name,String psd) {  
        Toast.makeText(mContxt, "账号:"+name+" 密码:"+psd, 0).show();
    }

} 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

这里有一个构造方法和函数,这个fun2方法在html里面被调用。

下面看看html是怎么写的:

<!DOCTYPE html>

<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
    <style type="text/css">
div {
     align: center;
}
</style>
    <script type="text/javascript">
    function btnLogin() {
        var name = document.getElementById("name").value;
        var psd = document.getElementById("psd").value;
        login(name,psd);
    }
    function login(name,psd){
         myObj.fun2(name,psd);
    }

</script>
</head>
<body>
<div id="pid">
    账号登录
    <br/>
    <br/>
    账号 : <input id="name" type="text"></div>
<br/>
密码 : <input id="psd" type="password"></div>
<br/>
<br/>
记住密码<input type="checkbox"/> <a href="http://blog.youkuaiyun.com/qq_25193681/article/details/52117281" target="_blank">忘记密码</a>
<br/>
<br/>

<button onclick="btnLogin()">登录</button>
</div>
</body>
</html>
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41

有两个输入框,分别用于输入账号和密码,还有一个按钮,以及一个跳转的链接:

以上就是全部代码了,最后我将会把源码贴上:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值