作者:贞亭钟_432 | 来源:互联网 | 2023-09-13 14:05
因为要解析XML数据,首先要有一个XML数据的地址,为了演示效果,我这里自己配置了一个Web服务器,并在服务器的根目录下放了一个get_data.xml的文件,文件内容如下:
因为要解析XML数据,首先要有一个XML数据的地址,为了演示效果,我这里自己配置了一个Web服务器,并在服务器的根目录下放了一个get_data.xml的文件,文件内容如下:
1
Baidu Maps
1.0
2
Baidu Chrome
2.0
3
Baidu Play
3.0
我现在来访问一下这个xml数据的地址,效果图如下:
这里是为了演示,所以我才自己配置了一个Web服务器,通常情况下,我们都是已经拿到了这个xml数据的服务器地址,然后在进行请求数据,获取返回的数据,对返回的数据进行解析。
这里我是使用OkHttp进行网络请求,如不熟悉,请看我的另一篇文章:
使用OkHttp发送HTTP请求并显示返回的数据
添加网络权限,在AndroidManifest.xml文件中加入以下代码:
MainActivity的布局代码如下:
android:layout_
android:layout_
android:orientation="vertical">
MainActivity的java代码如下:
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private Button mBtn_sendRequest;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mBtn_sendRequest = findViewById(R.id.btn_send_request);
mBtn_sendRequest.setOnClickListener(this);
}
@Override
public void onClick(View v) {
if (v.getId() == R.id.btn_send_request) {
// 发送网络请求并读取的方法
sendRequestWithOkHttp();
}
}
private void sendRequestWithOkHttp() {
new Thread(new Runnable() {
@Override
public void run() {
try {
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
// 此处换成xml数据的服务器地址
.url("http://192.168.43.8/get_data.xml")
.build();
Response respOnse= client.newCall(request).execute();
String respOnseData= response.body().string();
// 调用方法解析XML数据
parseXMLWithPull(responseData);
} catch (IOException e) {
e.printStackTrace();
}
}
}).start();
}
private void parseXMLWithPull(String xmlData) {
try {
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
XmlPullParser xmlPullParser = factory.newPullParser();
// 将服务器返回的XML数据设置进去
xmlPullParser.setInput(new StringReader(xmlData));
// 得到当前的解析事件
int evenType = xmlPullParser.getEventType();
String id = "";
String name = "";
String version = "";
// 在while循环中不断的进行解析
// 如果当前事件不等于xmlPullParser.END_DOCUMENT,说明解析工作还没完成,调用next()方法后可以获取下一个解析事件
while (evenType != xmlPullParser.END_DOCUMENT) {
// 得到当前节点的名字
String nodeName = xmlPullParser.getName();
switch (evenType) {
// 开始解析某个节点
case XmlPullParser.START_TAG:
if ("id".equals(nodeName)) {
// 调用nextText()方法获取节点内具体的内容
id = xmlPullParser.nextText();
} else if ("name".equals(nodeName)) {
name = xmlPullParser.nextText();
} else if ("version".equals(nodeName)) {
version = xmlPullParser.nextText();
}
break;
// 完成解析某个节点
case XmlPullParser.END_TAG:
// 每当解析完一个app节点后就将获取到的内容打印出来
if ("app".equals(nodeName)) {
Log.d("MainActivity", id);
Log.d("MainActivity", name);
Log.d("MainActivity", version);
}
break;
default:
break;
}
// 获取下一个解析事件
evenType = xmlPullParser.next();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
我们来仔细看下parseXMLWithPull()方法中的代码吧。这里首先要获取到一个XmlPullParserFactory的实例,并借助这个实例得到XmlPullParser对象,然后调用XmlPullParser的setInput()方法将服务器返回的XML数据设置进去就可以开始解析了。解析过程也非常简单,通过getEventType()可以得到当前的解析事件,然后在一个while循环中不断地进行解析,如果当前的解析事件不等于XmlPullParser.END_DOCUMENT,说明解析工作还没完成,调用next()方法后可以获取下一个解析事件。
在while循环中,我们通过getName()方法得到当前节点的名字,如果发现节点名字等于id、name或version,就调用nextText()方法来获取节点内具体的内容,每当解析完一个app节点后就将获取的内容打印出来。
最终打印的效果图如下: