首先我想强调一点。这个登陆的模块最好是放在另外一个线程里面来实现。否则有可能会爆出一系列的问题,

然后再与主UI 交互。这样就不会爆ANR异常

1.对于登陆模块的。首先大体的逻辑肯定是要清晰的。

                    //在这个登陆另起的线程中
                    //第一步首先要推断 是否有网络存在
                    //第二步分别对 是否有网络做对应的处理
                    //第三步分别对 有网络做对应的处理
                    //第四步分别对 没有网络做对应的处理

2.确定登陆逻辑之后接下来是怎样实现功能的问题,以下我给出最基本的核心代码

a.推断 是否有网络存在

    /**
     * 推断当前环境下网络是否可用
     *
     * @param context
     * @return true 可用  false 不可用
     */
    public static boolean isNetworkAvailable(Context context) {
        ConnectivityManager mConnectivity = (ConnectivityManager) context
                .getSystemService(Context.CONNECTIVITY_SERVICE);
        TelephonyManager mTelephony = (TelephonyManager) context
                .getSystemService(Context.TELEPHONY_SERVICE);
        // 检查网络连接。假设无网络可用。就不须要进行连网操作等
        NetworkInfo info = mConnectivity.getActiveNetworkInfo();
        if (info == null || !mConnectivity.getBackgroundDataSetting()) {
            return false;
        }
        // 推断网络连接类型,仅仅有在3G或wifi里进行一些数据更新。
        int netType = info.getType();
        int netSubtype = info.getSubtype();
        if (netType == ConnectivityManager.TYPE_WIFI) {
            return info.isConnected();
        } else if (netType == ConnectivityManager.TYPE_MOBILE
                && netSubtype == TelephonyManager.NETWORK_TYPE_UMTS
                && !mTelephony.isNetworkRoaming()) {
            return info.isConnected();
        } else {
            return false;
        }
    }

b.假设是网络可用的话,则继续下一步;假设没有网络的话,就Toast提醒用户开启网络

    /**
     * 依据username和password登陆
     *
     * @param uname
     * @param pwd
     */
    private void login(String uname, String pwd) {
        try {
            HttpParams httpParams = new BasicHttpParams();
            HttpConnectionParams.setConnectionTimeout(httpParams, 10000);
            HttpConnectionParams.setSoTimeout(httpParams, 10000);
            
            HttpClient httpclient = new DefaultHttpClient(httpParams);
            String uri = "http://xxx.xxx.xxx.xxxx:8080/api/v1/auth/login";
            HttpPost httppost = new HttpPost(uri);
            //加入http头信息
            httppost.addHeader("Content-Type", "application/json");
            //http post的json数据格式: {"id":"TOD4727","passwd":"8111668ebce8f8d27fc2f98391cf20c1"}
            JSONObject obj = null;
            HttpResponse response = null;
            obj = new JSONObject();
            obj.put("id", uname);
            obj.put("passwd", MD5.GetMD5Code(pwd));
//            System.out.println("-----post the data is  ++++ " + obj.toString());
            httppost.setEntity(new StringEntity(obj.toString()));    
            response = httpclient.execute(httppost);
            int code = response.getStatusLine().getStatusCode();
            
            if (200 == code) { //訪问正常
                String rev = EntityUtils.toString(response.getEntity());//返回json格式:{"code":"1000","message":"ok","description":""}
                System.out.println("-----get the data is  ++++  " + rev);
                obj = new JSONObject(rev);
                String resCode = obj.getString("code");
                
                if("1000".equals(resCode)){//username和password正确
                    rememberUsernameAndPassword();
                    Intent mainIntent = new Intent(LoginActivity.this, MainActivity.class);
                    startActivity(mainIntent);
                    finish();
                }else if("1002".equals(resCode)){//username不存在
                    Message msg = handler.obtainMessage();
                    msg.what = USER_NOT_EXIST;
                    handler.sendMessage(msg);
                }else if("1003".equals(resCode)){//password错误
                    Message msg = handler.obtainMessage();
                    msg.what = ERROR_PASSWORD;
                    handler.sendMessage(msg);
                }
                
            }else{//訪问出现异常
                Message msg = handler.obtainMessage();
                msg.what = NET_PROBLEM;
                handler.sendMessage(msg);
            }
        } catch (Exception e) {//訪问出现异常
            // TODO Auto-generated catch block
            Message msg = handler.obtainMessage();
            msg.what = NET_PROBLEM;
            handler.sendMessage(msg);
            e.printStackTrace();
        }

    }
    //这些handler发送的信息交付给handler去处理。做出对应的处理

    
   

Android APP 登陆模块的更多相关文章

  1. 初步探究Android App API接口测试--实战

    一.Android App API接口测试 1.如何学好Android App API接口测试 postman可以用来实现API接口自动化测试,但是也有弊端,无法实现接口测试数据的参数化,为了达到接口 ...

  2. MVP应用在android app上

    使用MVP模式来解耦activity中业务代码和界面代码.在activity中,将其中的业务抽象到presenter层:将其中的界面代码抽象到View层. MVP模式: 一个软件被划分成三层,View ...

  3. Android App的设计架构:MVC,MVP,MVVM与架构经验谈

    相关:http://www.cnblogs.com/wytiger/p/5996876.html 和MVC框架模式一样,Model模型处理数据代码不变在Android的App开发中,很多人经常会头疼于 ...

  4. [转]Android App整体架构设计的思考

    1. 架构设计的目的 对程序进行架构设计的原因,归根到底是为了提高生产力.通过设计使程序模块化,做到模块内部的高聚合和模块之间的低耦合.这样做的好处是使得程序在开发的过程中,开发人员只需要专注于一点, ...

  5. [转]设计一款Android App总结

    开发工具的选择 开发工具我将选用Android Studio,它是Google官方指定的Android开发工具,目前是1.2.2稳定版,1.3的预览版也已经发布了.Android Studio的优点就 ...

  6. 【Bugly安卓开发干货分享】Android APP 快速 Pad 化实现

    项目背景 采用最新版本手机 APP(之后称为 MyApp)代码,实现其 Pad 化,为平板和大屏手机用户提供更好的体验.为实现 MyApp 的 Pad 化工作,需要我们首先来了解一下 MyApp 项目 ...

  7. 不可或缺 Windows Native (25) - C++: windows app native, android app native, ios app native

    [源码下载] 不可或缺 Windows Native (25) - C++: windows app native, android app native, ios app native 作者:web ...

  8. How To Use Proguard in Android APP

    在Android开发完成即将发布给用户使用时,还有最后重要的一步:代码混淆,这时候,Proguard就派上用场了,大家谁也不想辛辛苦苦写的代码太容易被别人反编译过来,而Proguard就是帮我们实现这 ...

  9. 【转载】Android app 安全测试调研及执行

    本文来源于:http://testerhome.com/topics/2209 一.通过在线工具进行测试 1.腾讯金刚审计系统http://service.security.tencent.com 优 ...

随机推荐

  1. LINUX VSFTP配置及安装

    ------------------转载:亲身实践,确实好用(http://www.cnblogs.com/jack-Star/p/4089547.html) 1.VSFTP简介 VSFTP是一个基于 ...

  2. python常用函数 W

    with…as with 语句适用于对资源进行访问的场合,确保不管使用过程中是否发生异常都会执行必要的“清理”操作,释放资源,比如文件使用后自动关闭.线程中锁的自动获取和释放等.当python执行wi ...

  3. php函数漏洞

    1.ereg — 正则表达式匹配 此函数遇 %00 截断. <?php $a = $_GET['pwd']; var_dump(ereg ("^[0-9]+$", $a)); ...

  4. css 块级格式化上下文(BFC)

    一.块级格式化上下文(BFC) 1.什么是块级格式化上下文? Block Formatting Contexts (BFC,块级格式化上下文)就是一个块级元素 的渲染显示规则 (可以把 BFC 理解为 ...

  5. Tomcat的作用思考及NIO在Tomcat中的应用模型

    Tomcat的作用 平时写完web程序都是直接点击启动,就可以在本机浏览器访问了.但是仔细想想,我们似乎都没有写过浏览器与servlet通信的代码,也没有写过创建request.reponse的代码. ...

  6. 向Hive中导入数据的方式

    一.Hive客户端:根据数据源不同划分 1.从本地文件系统中导入数据到hive表中: load data local inpath "path" [OVERWRITE] into ...

  7. TPS、QPS和系统吞吐量的区别和理解

    参考:https://blog.csdn.net/u010889616/article/details/83245695 一.QPS/TPSQPS:Queries Per Second意思是“每秒查询 ...

  8. 微信小程序-没有找到 node_modules 目录的解决办法

    初次在微信开发者工具构建npm 没有找到 node_modules 目录的解决办法 第一步:设置-->项目设置-->使用npm模块 第二步:右键目录下miniprogram-->终端 ...

  9. python学习笔记(十一)处理json

    json串就是字符串,json串里必须是双引号 d={'car':{'color':'red','price':100,'count':50}, '爱分叉':{'color':'red','price ...

  10. 【CF1257C】Dominated Subarray【贪心】

    题意:给定一个数组,求最小的字数组使得数组里存在至少一对重复元素 题解:每个点求出他的后继在哪,然后每次贪心就这个点到他的后继为一个子数组,求出最小的就是答案 #include<iostream ...