(一)WebView的用法
1、WebView也是一个普通的控件。
2、常用用法:
 WebView webView = (WebView)findViewById(R.id.web_view);
webView.getSettings( ).setJavaScriptEnabled(true); //让webView支持javascript脚本
webView.setWebViewClient(new WebViewClient( ){
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url){
view.loadUrl(url); //根据传入的参数再去加载新的网页
return true; //表示当前WebView可以处理打开新网页的请求,不用借助系统浏览器
}
});
webView.loadUrl("http://www.baidu.com");

3、使用任何网络功能的程序都要申请权限:

 <uses-permission android:name="android.permission.INTERNET" />

(二)使用HttpURLConnection访问网络

1、步骤如下:
(1)创建一个URL对象,然后使用其openConnection创建一个HttpURLConnection对象:
 URL url = new URL("http://www.baidu.com");
connection = (HttpURLConnection) url.openConnection();

(2)设置HttpURLConnection是GET方法还是POST方法:

 connection.setRequestMethod("GET");

(3)对HttpURLConnection进行其他的设置:

 connection.setConnectTimeout(8000);    //设置连接超时的毫秒数
connection.setReadTimeout(8000); //设置读取超时的毫秒数

(4)用HttpURLConnection对象的getInputStream方法获取服务器的返回输入流InputStream对象:

 InputStream in = connection.getInputStream();

(5)对输入流进行读取:

 BufferedReader reader = new BufferedReader(
new InputStreamReader(in));
StringBuilder response = new StringBuilder();
String line;
while ((line = reader.readLine()) != null) {
response.append(line);
}

(6)用disconnect方法关闭这个HTTP连接:

 connection.disconnect();

2、注意:

(1)网络请求要放在子线程里。
(2)在子线程里网络请求获取返回数据后,如果要进行UI操作,则要采用异步消息处理方法。
(3)要申请网络权限。
 
(三)使用HttpClient访问网络
1、HttpClient是一个接口类,是Apache提供的HTTP网络访问接口,从一开始就被引入到了Android API中。
2、使用步骤:
(1)创建HttpClient实例:
 HttpClient httpClient = new DefaultHttpClient();
(2)根据发起请求的类型不同,下面的第(2)步的步骤也不同:
①GET请求:
 HttpGet httpGet = new HttpGet("http://10.0.2.2:8081/get_data.xml");

②POST请求:

 HttpPost httpPost = new HttpPost("http://www.baidu.com");
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("username","admin"));
params.add(new BasicNameValuePair("password","123456"));
UrlEncodedFormEntity entity = new UrlEncodedFormEntity(params, "utf-8");
httpPost.setEntity(entity);

(3)获取服务器返回值:

 HttpResponse httpResponse = httpClient.execute(httpGet);

(4)判断返回状态码,如果等于200就表示请求和响应都成功了:

 if (httpResponse.getStatusLine().getStatusCode() == 200) {
HttpEntity entity = httpResponse.getEntity();
String response = EntityUtils.toString(entity, "utf-8");
... //其他操作
}

3、注意:HttpClient访问网络同样要放在子线程里、申请网络权限。

(四)使用回调机制封装HttpURLConnection操作来创建HttpUtil类
1、创建HttpCallbackListener接口:
 public interface HttpCallbackListener {
void onFinish(String response); //在服务器成功响应请求时调用
void onError(Exception e); //进行网络操作出错时调用
}

2、创建HttpUtil类:

 import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL; public class HttpUtil {
public static void sendHttpRequest(final String address,final HttpCallbackListener listener) {
new Thread(new Runnable() {
@Override
public void run() {
HttpURLConnection connection = null; try {
URL url = new URL(address);
connection = (HttpURLConnection) url.openConnection(); connection.setRequestMethod("GET");
connection.setConnectTimeout(8000);
connection.setReadTimeout(8000);
connection.setDoInput(true);
connection.setDoOutput(true); InputStream in = connection.getInputStream();
BufferedReader reader = new BufferedReader(
new InputStreamReader(in));
StringBuilder response = new StringBuilder();
String line; while ((line = reader.readLine()) != null) {
response.append(line);
} if (listener != null) {
// 回调onFinish方法
listener.onFinish(response.toString());
} } catch (Exception e) {
if (listener != null) {
listener.onError(e);
}
} finally {
if (connection != null) {
connection.disconnect();
}
}
}
}).start();
}
}

3、使用时这样使用:

 HttpUtil.sendHttpRequest("http://www.baidu.com",new HttpCallBackListener(){
@Override
public void onFinish(String response){
//在这里根据返回内容执行具体的逻辑
} @Override
public void onError(Exception e){
//在这里对异常情况进行处理
}
});

(五)解析XML数据

1、安装Apache服务器:下载安装包,然后安装成功后启动服务器,在浏览器里输入127.0.0.1,会看到Apache的字样。
2、在Apache安装目录:...\Apache\htdocs目录下,可以新建一个xml文件,命名为get_data.xml,加入内容,然后在浏览器里输入:127.0.0.1/get_data.xml(在手机模拟器里要输入:10.0.2.2/get_data.xml),就会显示出该文件的内容。
3、编写的XML数据的格式如下:
 <apps>
<app>
<id>1</id>
<name>Google Maps</name>
<version>1.0</version>
</app>
<app>
<id>2</id>
<name>Chrome</name>
<version>1.8</version>
</app>
<app>
<id>3</id>
<name>Google Play</name>
<version>3.2</version>
</app>
</apps>

4、用Pull方式解析XML数据:

 private void parseXMLWithPull(String xmlData) {
try {
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
XmlPullParser xmlPullParse = factory.newPullParser();
xmlPullParse.setInput(new StringReader(xmlData));
int eventType = xmlPullParse.getEventType(); String id = "";
String name = "";
String version = ""; while (eventType != XmlPullParser.END_DOCUMENT) {
String nodeName = xmlPullParse.getName();
switch (eventType) {
// 开始解析某个结点
case XmlPullParser.START_TAG: {
if ("id".equals(nodeName)) {
id = xmlPullParse.nextText();
} else if ("name".equals(nodeName)) {
name = xmlPullParse.nextText();
} else if ("version".equals(nodeName)) {
version = xmlPullParse.nextText();
}
}
break;
// 完成解析某个结点
case XmlPullParser.END_TAG: {
if ("app".equals(nodeName)) {
Log.d("MainActivity", "id is " + id);
Log.d("MainActivity", "name is " + name);
Log.d("MainActivity", "version is " + version);
}
}
break;
default:
break;
} eventType = xmlPullParse.next();
}
} catch (Exception e) {
e.printStackTrace();
}
}
5、用SAX方式解析XML数据步骤:
(1)创建ContentHandler 类继承自DefaultHandler并重写5个方法:
 import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; import android.util.Log; public class ContentHandler extends DefaultHandler {
private String nodeName;
private StringBuilder id;
private StringBuilder name;
private StringBuilder version; @Override
public void startDocument() throws SAXException {
id = new StringBuilder();
name = new StringBuilder();
version = new StringBuilder();
} @Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
// 记录当前结点名
nodeName = localName;
} @Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// 根据当前结点名判断将内容添加到哪一个StringBuilder对象中
if ("id".equals(nodeName)) {
id.append(ch, start, length);
} else if ("name".equals(nodeName)) {
name.append(ch, start, length);
} else if ("version".equals(nodeName)) {
version.append(ch, start, length);
}
} @Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
// 用trim方法去掉空白字符
if ("app".equals(localName)) {
Log.d("MainActivity", "id is " + id.toString().trim());
Log.d("MainActivity", "name is " + name.toString().trim());
Log.d("MainActivity", "version is " + version.toString().trim()); // 将StringBuilder清空
id.setLength(0);
name.setLength(0);
version.setLength(0);
}
} @Override
public void endDocument() throws SAXException {
}
}

(2)写具体方法:

 private void parseXMLWithSAX(String xmlData) {
try {
SAXParserFactory factory = SAXParserFactory.newInstance();
XMLReader xmlReader = factory.newSAXParser().getXMLReader();
ContentHandler handler = new ContentHandler(); xmlReader.setContentHandler(handler); // 开始执行解析
xmlReader.parse(new InputSource(new StringReader(xmlData)));
} catch (Exception e) {
e.printStackTrace();
}
}
(六)解析Json数据
  见我的博客园文章:用GSON解析Json格式数据,这里不再详写。

 

  【本章结束】

随机推荐

  1. Mac显示和隐藏隐藏文件

    显示:defaults write com.apple.finder AppleShowAllFiles -bool true 隐藏:defaults write com.apple.finder A ...

  2. Android学习之ItemTouchHelper实现RecylerView的拖拽以及滑动删除功能

    今天在群里见大神们提到控件的拖动以及滑动删除的效果实现,就在网上找了资料ItemTouchHelper学习,并实现其功能.不胜窃喜之至,忍不住跟大家分享一下,如今就对学习过程做下简介.帮助大家实现这样 ...

  3. android学习十四(android的接收短信)

    收发短信是每一个手机主要的操作,android手机当然也能够接收短信了. android系统提供了一系列的API,使得我们能够在自己的应用程序里接收和发送短信. 事实上接收短信主要是利用我们前面学过的 ...

  4. IOS设计模式浅析之建造者模式(Builder)

    定义 "将一个复杂对象的构建与它的表现分离,使得同样的构建过程可以创建不同的表现". 最初的定义出现于<设计模式>(Addison-Wesley,1994). 看这个概 ...

  5. go的sync.Map

    sync.Map这个数据结构是线程安全的(基本类型Map结构体在并发读写时会panic严重错误),它填补了Map线程不安全的缺陷,不过最好只在需要的情况下使用.它一般用于并发模型中对同一类map结构体 ...

  6. HTML 网页中以超链接的方式调用iphone 手机的app

    2011-11-13 14:36:33|  分类: 随笔 |  标签:iphone  调用iphone手机app  |举报|字号 订阅     <1>. 调用iphone 手机地图APP的 ...

  7. github+hexo+node.js搭建个人博客基本过程及遇到的问题

    一,所需工具 1,github账号+Gitclient+配置SSH key 2,安装node.js. 3,安装Hexo. 当中,github pages是我们用来部署我们本地的博客到github上的. ...

  8. js array filter pop push shift unshift方法

    JavaScript Array filter() 方法  JavaScript Array 对象 实例 返回数组 ages 中所有元素都大于 18 的元素: var ages = [32, 33,  ...

  9. Working with JSON in C# & VB

    Introduction Whilst JSON is a compact and easy to read cross-language storage and data exchange form ...

  10. sourcenav安装

    $ ./configure之后会出现 configure: error: ./configure failed for unixconfigure: error: ./configure failed ...