Android解析XML文件
XML文件和获取XML值
XML文件样例
<?xml version="1.0" encoding="utf-8"?>
<citys>
<city name="CAF">中非</city>
<city name="TCD">乍得</city>
<city name="CHL">智利</city>
<city name="CHN">中国</city>
<city name="HKG">香港</city>
<city name="MAC">澳门</city>
<city name="TWN">台湾</city>
</citys>
获取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;
}
Android解析XML文件的更多相关文章
- android解析xml文件的方式
android解析xml文件的方式 作者:东子哥 ,发布于2012-11-26,来源:博客园 在androd手机中处理xml数据时很常见的事情,通常在不同平台传输数据的时候,我们就可能使用xm ...
- Android 解析XML文件和生成XML文件
解析XML文件 public static void initXML(Context context) { //can't create in /data/media/0 because permis ...
- Android解析xml文件-采用DOM,PULL,SAX三种方法解析
解析如下xml文件 <?xml version="1.0" encoding="UTF-8"?> <persons> <perso ...
- android解析xml文件方法之一-----DOM
Hello.xml文件 <dict num="219" id="219" name="219"> <key>hell ...
- [android]解析XML文件的方法有三种:PULL,DOM,SAM
PULL 的工作原理: XML pull提供了开始元素和结束元素.当某个元素开始时,可以调用parser.nextText从XML文档中提取所有字符数据.当解析到一个文档结束时,自动生成EndDocu ...
- Android开发学习---使用XmlPullParser解析xml文件
Android中解析XML的方式主要有三种:sax,dom和pull关于其内容可参考:http://blog.csdn.net/liuhe688/article/details/6415593 本文将 ...
- 【Android学习笔记】XmlResourceParser解析xml文件
最近学习Android时,需要用到解析XML文件里的数据,可以用XmlResourceParser来解析xml文件,正好将此记录下来. XmlResourceParser里常用的字段和方法 首先先给出 ...
- Android pull解析xml文件
本文介绍android中使用pull来解析xml文件 先自己写一个xml文件,存一些天气信息 <?xml version="1.0" encoding="UTF-8 ...
- android——使用pull解析xml文件
1.persons.xml 将persons.xml文件放到src目录下.其代码如下: <?xml version='1.0' encoding='UTF-8' standalone='yes' ...
随机推荐
- Java匹马行天下之JavaSE核心技术——Java基础语法
Java基础语法 一. 认识Java 1. Java 简介 java 是一种高级的面向对象的程序设计语言,使用Java语言编写的程序时跨平台的.从pc到手机,都有Java开发的程序和游戏,Java ...
- Django model select的各种用法详解
<Django model update的各种用法介绍>文章介绍了Django model的各种update操作,这篇文章就是她的姊妹篇,详细介绍Django model select的用 ...
- asp.net mvc开发过程中的一些小细节
现在做网站用mvc越来越普及了,其好处就不说了,在这里只记录一些很多人都容易忽视的地方. 引用本地css和js文件的写法 这应该是最不受重视的地方,有同事也说我有点小题大作,但我觉得用mvc还是得有一 ...
- C#单元测试分享ppt
单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证.对于单元测试中单元的含义,一般来说,要根据实际情况去判定其具体含义,如C语言中单元指一个函数,Java里单元指一个类, ...
- JavaScript设计模式----装饰者模式
装饰者模式的定义: 装饰者(decorator)模式能够在不改变对象自身的基础上,在程序运行期间给对像动态的添加职责.与继承相比,装饰者是一种更轻便灵活的做法. 装饰者模式的特点: 可以动态的给某个对 ...
- Spring Cloud Zuul 网关使用与 OAuth2.0 认证授权服务
API 网关的出现的原因是微服务架构的出现,不同的微服务一般会有不同的服务地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信,会有以下的问题: 客户端会 ...
- 在线画UML图的工具
工作需要在线画各种UML图,类图.协作图.用例图等等,调查了一些在线画UML图的工具,有的做的很好但要收费,例如:http://www.gliffy.com/,发现现在免费好用的是ProcessOn: ...
- 比Python、Java更快的 Go 语言,能否称霸江湖?
关注之后加星标,江湖要事早知道 文章来源:jb51.net 有一种语言堪称比语言排行榜前五热门选手的Python.Java更快,它就是GO语言. Go于2009年11月正式宣布推出,成为开放源代码 ...
- Spring Boot + Spring Cloud 实现权限管理系统 后端篇(十九):服务消费(Ribbon、Feign)
技术背景 上一篇教程中,我们利用Consul注册中心,实现了服务的注册和发现功能,这一篇我们来聊聊服务的调用.单体应用中,代码可以直接依赖,在代码中直接调用即可,但在微服务架构是分布式架构,服务都运行 ...
- docker学习系列(二):使用Dockerfile创建自己的镜像
dockerfile可以允许我们自己创建镜像,通过编写里面的下载软件命令,执行docker build 即可生成镜像文件. 初尝dockerfile 新建一个目录test,然后进入这个目录,创建一个名 ...