网络编程
只有通过网络编程才能保持app的鲜活性,持久性
- 客户端Client:移动应用
- 服务器端Server:提供数据,服务,资源
- 请求Request:客户端向服务器索取数据的一种行为
- 响应Response:服务器对客户端的请求做出的反应
作为移动开发工程师,主要的精力都是放在前段开发
Dom解析
解析的数据xml代码如下: <Movies>
<Movie id="1">
<name>愤怒的小鸟</name>
<type>animation</type>
<year>2015</year>
</Movie>
<Movie id="2">
<name>叶问</name>
<type>action</type>
<language>chinese</language>
</Movie>
</Movies>
- 首先必须一下两个对象
// 创建DocumentBuilder对象
DocumentBuilder db = dbf.newDocumentBuilder();
// 获取Document
Document document = db.parse("Movie.xml");
- 得到一个节点的集合,也就是
NodeList movies = document.getElementsByTagName("Movie")
得到一个最外层多少项,然后利用for循环进行遍历:得到属性值和属性名: - 得到子节点为对子节点元素进行遍历,得到节点值和节点名:
for (int j = 0; j < attrs.getLength(); j++) { Node attr = attrs.item(j); attr.getNodeName(); attr.getNodeValue(); System.out.println("属性名为:" + attr.getNodeName() + " "); System.out.println("属性值为:" + attr.getNodeValue()); } NodeList chilNodes = movie.getChildNodes(); for (int k = 0; k < chilNodes.getLength(); k++) { Node chilid = chilNodes.item(k); // 节点为元素节点时输出,(空格为文本节点) if (chilid.getNodeType() == document.ELEMENT_NODE) { System.out.print("节点名为:" + chilid.getNodeName() + "*****"); System.out.println("节点值为:" + chilid.getFirstChild().getNodeValue()); } } System.out.println("第" + (i + 1) + "电影解析结束"); }
Sax解析
-
首先获取:
SAXParserFactory spf = SAXParserFactory.newInstance();
SAXParser saxParser = spf.newSAXParser();
saxParser.parse("Movie.xml", new MyHandler();//这个开始解析, 我们必须自定义MyHandler对象继承DefaultHandler,重写里面五个方法
startDocument() //开始解析执行这个方法
endDocument() //结束解析执行这个方法
startElement() //解析到<Movie>这时调用这个,多次回调
endElement() //解析到</Movie>这时回调这个
characters() //读到节点时,自动调用这个方法
pull解析
XmlResourceParser parser = getResources().getXml(R.xml.movie);
int type;
try {
type = parser.getEventType();
while (type != XmlResourceParser.END_DOCUMENT) {
if (type == XmlResourceParser.START_DOCUMENT) {
System.out.println("开始解析");
}
if (type == XmlResourceParser.START_TAG) {
if ("Movie".equals(parser.getName())) {
String idString = parser.getAttributeValue(null, "id");
System.out.println("ID" + idString);
}
if ("name".equals(parser.getName())) {
System.out.println("name" + parser.nextText());
}
}
if (type == XmlResourceParser.END_TAG) {
// if ("movie".equals(parser.getName())) {
// movielist.add(movie);
// movie=null;
// }
}
type = parser.next();
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Json解析数据
{ Movies :[ {id:1,name:愤怒的小鸟}, {id:2,name:叶问} ] }
{}表示一个JsonObject对象
[]表示一个JsonArray对象
先新建JSONObject对象
JSONObject jsonObject = new JSONObject(JSONData)
// jsonTokener解析就如下方法获取其他一样
//JSONTokener jsonTokener=new JSONTokener(JSONData);
//JSONObject jsonObject=(JSONObject)jsonTokener.nextValue();
在根据key去取数据如jsonObject.getString("name")
Gson解析数据
谷歌官方推荐的,需要导入第三方jar包
解析的json数据如下: {name:张三,age:25,phone:[131,132],scores:[{id:语文,score:100},{id:数学,score:60},{id:化学,score:120}]}
如果用Gson解析json数据,那么bean类的属性值必须和json数据类型一致,遇到一个JsonArray就必须写ArrayList<String>.遇到一个JSonObject就必须写个类
Gson gson = new Gson();
Student student = gson.fromJson(JSONData, Student.class);
Student做如下封装,注意属性名
public class Student {
public String name;
public String age;
public ArrayList<String> phone = new ArrayList<>();
public ArrayList<Score> scores = new ArrayList<>();
public class Score {
public String id;
public String score;
@Override
public String toString() {
return "id:" + id + "score:" + score;
}
}
@Override
public String toString() {
return "name:" + name + "age:" + age + "phone:" + phone.get(0)
+ "phone:" + phone.get(1) + "scores:" + scores.toString();
}
}