资讯专栏INFORMATION COLUMN

Android解析XML文件

pkwenda / 637人阅读

摘要:文件和获取值文件样例中非乍得智利中国香港澳门台湾获取内容找到文件循环解析获取标签名获取标签里的值获取标签的内容升级发送请求获取输入流存放在服务器的地址发送请求,获取相应码使用解析器,开始解析这个流解析文件对节点的事件类型进行判断,就可

XML文件和获取XML值 XML文件样例

 
   中非
   乍得
   智利
   中国
   香港
   澳门
   台湾
获取XML内容
private String getNationality(String str){
    XmlResourceParser xpr = getResources().getXml(R.xml.nationality);// 找到xml文件
    try {
        // 循环解析
        while (xpr.getEventType() != XmlResourceParser.END_DOCUMENT) {
            if (xpr.getEventType() == XmlResourceParser.START_TAG) {
                String name = xpr.getName(); //获取标签名
                if (name.equals("city")) {
                    if(str.equals(xpr.getAttributeValue(null, "name"))){//获取标签里的值
                        return xpr.nextText();//获取标签的内容
                    }
                }
            }
            try {
                xpr.next();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    } catch (XmlPullParserException | IOException e) {
        e.printStackTrace();
    }
    return "null";
}
升级APK 发送请求获取输入流
Thread thread = new Thread() {
    @Override
    public void run() {
        super.run();
        //XML存放在ftp服务器的地址
        String path = FileUtils.getDevice_address()+"News.XML";
        try {
            URL url = new URL(path);
            HttpURLConnection conn = (HttpURLConnection) url
                    .openConnection();
            conn.setRequestMethod("GET");
            conn.setConnectTimeout(5000);
            conn.setReadTimeout(5000);
            //发送http GET请求,获取相应码
            if (conn.getResponseCode() == 200) {
                InputStream is = conn.getInputStream();
                //使用pull解析器,开始解析这个流
                parseNewsXml(is);
            }
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
};
thread.start();    
解析XML文件
private void parseNewsXml(InputStream is) {
    XmlPullParser xp = Xml.newPullParser();
    try {
        xp.setInput(is, "utf-8");
        //对节点的事件类型进行判断,就可以知道当前节点是什么节点
        int type = xp.getEventType();
        News news = null;
        while (type != XmlPullParser.END_DOCUMENT) {
            switch (type) {
                case XmlPullParser.START_TAG:
                    if ("newslist".equals(xp.getName())) {
                        newsList = new ArrayList<>();
                        break;
                    } else if ("news".equals(xp.getName())) {
                        news = new News();
                        break;
                    } else if ("name".equals(xp.getName())) {
                        String name = xp.nextText();
                        news.setName(name);
                        break;
                    } else if ("code".equals(xp.getName())) {
                        String code = xp.nextText();
                        news.setCode(code);
                        break;
                    }
                case XmlPullParser.END_TAG:
                    if ("news".equals(xp.getName())) {
                        newsList.add(news);
                    }
                    break;
                 default:
                    break;
            }
            //解析完当前节点后,把指针移动至下一个节点,直至节点完毕,并返回它的事件类型
            type = xp.next();
        }
        // 发消息
        handler.sendEmptyMessage(1);
    } catch (Exception e) {
        e.printStackTrace();
    }
}
开始下载
//获取下载管理器
DownloadManager manager =(DownloadManager)mContext.getSystemService(mContext.DOWNLOAD_SERVICE);

handler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
        super.handleMessage(msg);
        News news = newsList.get(0);
        Log.i("aii", "XML: "+news.getCode()+",apk:"+getPackageInfo(mContext));
        if(Integer.valueOf(news.getCode())>Integer.valueOf(getPackageInfo(mContext))){
           if(dowmCliek) {
                //开启进度条线程
                isRun = true;
                dowmCliek = false;
                //更新APK前删除原来的安装包
                DownLoadApk.fileDelete(path + "/" + mAPK);
                //创建下载请求
                DownloadManager.Request down = new DownloadManager.Request(
                        Uri.parse(mWebsite));
                //设置允许使用的网络类型,这里是移动网络和wifi都可以
                down.setAllowedNetworkTypes(DownloadManager.Request.NETWORK_MOBILE | DownloadManager.Request.NETWORK_WIFI);
                //禁止发出通知,既后台下载
                down.setShowRunningNotification(true);
                //不显示下载界面
                down.setVisibleInDownloadsUi(true);
                //标题
                down.setDestinationInExternalFilesDir(mContext, null, "XXX升级中...");
                //将下载请求放入队列,返回下载id
                downId = manager.enqueue(down);
            }else{
                Toast.makeText(mContext,"升级中...",Toast.LENGTH_SHORT).show();
            }
        }else{
                Toast.makeText(mContext,"已是最新版本无需升级...",Toast.LENGTH_SHORT).show();
        }
    }
};
跟踪下载进度
//定时任务
ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(1);
scheduledExecutorService.scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {
                if(isRun) {
                    Message msg = mHandler.obtainMessage();
                    msg.what = 1;
                    mHandler.sendMessage(msg);
                }
            }
        }, 0, 100, TimeUnit.MILLISECONDS);//延迟0,间隔100,单位毫秒

private Handler mHandler = new Handler(new Handler.Callback() {
    @Override
    public boolean handleMessage(Message msg) {
        switch (msg.what) {
            case 1:
                //android下载管理器
                DownloadManager.Query query = new DownloadManager.Query().setFilterById(downId);
                Cursor cursor = manager.query(query);
                if (cursor != null && cursor.moveToFirst()) {
                    //此处直接查询文件大小
                    long downSize = cursor.getLong(cursor.getColumnIndex(
                            DownloadManager.COLUMN_TOTAL_SIZE_BYTES));
                    //获取文件下载总大小
                    fileTotalSize =cursor.getLong(cursor.getColumnIndex(
                            DownloadManager.COLUMN_BYTES_DOWNLOADED_SO_FAR));
                    cursor.close();

                    Log.w("打印", "总大小" + downSize);
                    Log.w("打印", "下载进度 " + fileTotalSize);
                    if (fileTotalSize>0) {
                        NumberFormat numberFormat = NumberFormat.getInstance();
                        numberFormat.setMaximumFractionDigits(2);
                        String result = numberFormat.format((float)fileTotalSize/(float)downSize*100);
                        Log.w("打印", "downloaded size: " + result+"%");
                        downBtn.setText(result+"%");
                    }
                    //下载完毕
                    if(fileTotalSize==downSize) {
                        isRun = false;
                        downBtn.setText("点击升级");
                    }
                }
        }
        return true;
    }
});
 下载完毕启动安装
DownloadCompleteReceiver receiver = new DownloadCompleteReceiver();

//下载完成后的广播
class DownloadCompleteReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        if(intent.getAction().equals(DownloadManager.ACTION_DOWNLOAD_COMPLETE)){
            long downId = intent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, -1);
            if(downId!=-1) {
                //启动安装
                DownLoadApk.DownId(context,downId);
                dowmCliek=true;
            }
        }else{
            Toast.makeText(context, intent.getAction()+"下载失败", Toast.LENGTH_SHORT).show();
        }
    }
}

//启动下载完成广播
mContext.registerReceiver(receiver, new IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE));
 

安装APK


public class DownLoadApk {
    public static SharedPreferences sharedPrederences = null;
    //启动安装界面
    public static void DownId(Context context, long downId){
        DownloadManager mDownloadManager = (DownloadManager) context.getSystemService(Context.DOWNLOAD_SERVICE);
        Uri downloadUri = mDownloadManager.getUriForDownloadedFile(downId);
        startInstall(context, downloadUri);
   }
    /**
     * 跳转到安装界面
     * @param context 作用域
     * @param uri 包名
     */
    private static void startInstall(Context context, Uri uri) {
        Intent install = new Intent(Intent.ACTION_VIEW);
        install.setDataAndType(uri, "application/vnd.android.package-archive");
        install.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        context.startActivity(install);
    }
    //删除文件
    public static boolean fileDelete(String filePath) {
        File file = new File(filePath);
        if (file.exists() == false) {
            return false;
        }
        return file.delete();
    }
获取项目包名
private static String getPackageInfo(Context context) {
    PackageInfo pi = null;
    try {
        PackageManager pm = context.getPackageManager();
        pi = pm.getPackageInfo(context.getPackageName(),
                PackageManager.GET_CONFIGURATIONS);
        return pi.versionCode+"";
    } catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}

 

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/2881.html

相关文章

  • Android解析SetContentView过程

    摘要:布局加载对象的方式这里不多加以解析,只是通过将需要呈现的布局通过方法实现。文件加载方式文件是由加载是一个抽象类通过获取,然后方法载入和。而以上方式也大同小异都是通过反射创建。听说加载布局方式可能会更好更高效,但也待进一步证实和调研。 开始前 上周在github上看到关于提升Android布局加载速度的开源库X2C。对于Android开发设置布局不外乎于两种方式:xml、Java编码。过...

    cocopeak 评论0 收藏0
  • Android学习笔记2:Hello World程序解析

    摘要:创建工程中的一个。依赖包,包含包和等包。同时在中还有一个文件,它记录着基本信息管理文件。在下的则是的构建脚本。程序分析首先打开文件,从中可以找到如下代码这段代码表示对这个活动进行注册,没有在里注册的活动是不能使用的。 《第一行代码——Android》郭霖著Android Studio入门到精通 更多内容,请访问我的博客醒岛 Android Studio与Eclipse的一些不同 And...

    liujs 评论0 收藏0
  • 屏幕适配全方位解析

    摘要:需要注意的是,这种通过限定符分辨屏幕尺寸的方法,适用于之前。这种最小宽度限定符适用于之后,所以如果要适配全部的版本,就要使用限定符和文件同时存在于项目目录下。 1.屏幕适配概念 而随着支持Android系统的设备(手机、平板、电视、手表)的增多,设备碎片化、品牌碎片化、系统碎片化、传感器碎片化和屏幕碎片化的程度也在不断地加深。而我们今天要探讨的,则是对我们开发影响比较大的——屏幕的碎片...

    loonggg 评论0 收藏0
  • 屏幕适配全方位解析

    摘要:需要注意的是,这种通过限定符分辨屏幕尺寸的方法,适用于之前。这种最小宽度限定符适用于之后,所以如果要适配全部的版本,就要使用限定符和文件同时存在于项目目录下。 1.屏幕适配概念 而随着支持Android系统的设备(手机、平板、电视、手表)的增多,设备碎片化、品牌碎片化、系统碎片化、传感器碎片化和屏幕碎片化的程度也在不断地加深。而我们今天要探讨的,则是对我们开发影响比较大的——屏幕的碎片...

    mochixuan 评论0 收藏0
  • Android 初级面试者拾遗(前台界面篇)之 View 和 ViewGroup

    摘要:层面中可以通过方法拦截事件传递,返回代表同一事件列不再向下传递给子,返回代表事件继续传递,默认返回。同时注册两者事件传递顺序,方法将会先于方法执行,并且方法可能执行多次事件。如此反复执行初始化布局绘制过程容易造成性能问题。 View 和 ViewGroup View 是 Android 中最基本的 UI 组件,在屏幕上绘制一块矩形区域。 ViewGroup 是一种特殊的 View,它...

    sugarmo 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<