步奏分析,第一步,从文件中读取数据,用到IO流(inputStream)
第二部:把读取的xml文件解析文档(handler解析器 重写)
开始编码:
首先从文件中读取数据,通过网络服务器,获取服务器中文件的内容(http协议)代码如下:定义一个URL,通过HttpURLConnection 获取文件输入流。
public String download(String urlStr){
StringBuffer sb = new StringBuffer();
String line = null;
BufferedReader buffer = null;
try{
URL url = new URL(urlStr);
HttpURLConnection urlConn = (HttpURLConnection) url.openConnection();
buffer = new BufferedReader(new InputStreamReader(urlConn.getInputStream()));
while((line = buffer.readLine()) != null){
sb.append(line);
}
}catch(Exception e){
e.printStackTrace();
}finally{
try{
buffer.close();
} catch(Exception e){
e.printStackTrace();
}
}
return sb.toString();
}
第二步:传递一个该xml文件的Url地址,通过上面download方法获取,网络服务器中xml文件的内容,返回字符串。开始解析字符串中的内容
SAXParserFactory 解析工厂(sax),获取SAXParser中的XMLReader对象属性
重写DefaultHandler方法(具体的方法步奏,网上很详细)
注:在其中定义一个List<对象>返回该xml中的数据对象列表
XMLReader对象中首先要预处理handler
代码如下:还必须定义一个bean对象
private List<Mp3Info> parse(String xmlStr){ //返回的是一个数据对象
SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
List<Mp3Info> infos = new ArrayList<Mp3Info>();
try{
XMLReader xmlReader = saxParserFactory.newSAXParser().getXMLReader();
Mp3ListContentHandler mp3ListContentHandler = new Mp3ListContentHandler(infos);
xmlReader.setContentHandler(mp3ListContentHandler);
xmlReader.parse(new InputSource(new StringReader(xmlStr)));
}catch(Exception e){
e.printStackTrace();
}
return infos;
}