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

然后再与主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. [POJ3694]Network(Tarjan,LCA)

    [POJ3694]Network Description A network administrator manages a large network. The network consists o ...

  2. stream benchmark 交叉编译 on psoc

    之前有研究过这个,居然忘记了,看来确实是老了,没有盘过来. 如何下载,见 linux下载网页上的文件夹以及删除文件(stream) 出现了好几个问题 1. error while loading sh ...

  3. php内置函数分析之strrev()

    PHP_FUNCTION(strrev) { zend_string *str; char *e, *p; zend_string *n; if (zend_parse_parameters(ZEND ...

  4. vue @import css

    @import '~@/assets/scss/helpers/_mixin'; 原理:CSS loader 会把把非根路径的url解释为相对路径, 加~前缀才会解释成模块路径.

  5. Ajax工作原理及C/S与B/S的区别

    工作原理 Ajax 基本上就是把 JavaScript 技术和 XMLHttpRequest 对象放在 Web 表单和服务器之间.当用户填写表单时,数据发送给一些 JavaScript 代码而不是直接 ...

  6. windows2008R2-AD域控组策略设置与其它相关设置

    防火墙设置 修改>计算机配置>策略>安全设置>高级安全windows防火墙>高级安全windows防火墙 修改入站规则 1.组名-文件和打印机共享(SMB-In)> ...

  7. HDU 5386 Cover

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5386 题目大意:给一个初始矩阵(n×n).一个目标矩阵(n×n)和m个操作,要求找到一种操作顺序,使初 ...

  8. zabbix邮件报警通过脚本来发送邮件

    zabbix默认邮件报警会将各个报警接收人单独发送邮件,为了使邮件能以群发的方式统一一封邮件发送所有接收人,需要改成脚本的形式: sendemail.py: #!/usr/bin/python imp ...

  9. Proto3语法翻译

    本文主要对proto3语法翻译.参考网址:https://developers.google.com/protocol-buffers/docs/proto3 defining a message t ...

  10. 英语单词vendors

    vendors 来源——https://www.docker.com/products/docker-hub Share and Collaborate with Docker Hub Docker ...