android端从服务器抓取的几种常见的数据的处理方式
1、图片
public void look(View v) {
String path = et_path.getText().toString(); try {
URL url = new URL(path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET");
conn.setConnectTimeout(5000);
if(conn.getResponseCode() == 200){
InputStream is = conn.getInputStream();
Bitmap bitmap = BitmapFactory.decodeStream(is);
if(bitmap != null){
iv.setImageBitmap(bitmap);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
2、网页源码
public void look(View v) {
String path = et_path.getText().toString(); try {
URL url = new URL(path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET");
conn.setConnectTimeout(5000); if(conn.getResponseCode() == 200){
InputStream is = conn.getInputStream(); ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len = 0; //把流转化成文本信息
while((len = is.read(buffer)) != -1){
bos.write(buffer,0,len);
} String html = bos.toString();
html_tv.setText(html); is.close();
bos.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
3、Xml形式的数据
public List<HeaderNew> getHeaderNews(Context context) throws Exception{ String path = context.getResources().getString(R.string.serverurl); URL url = new URL(path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET");
conn.setConnectTimeout(5000); if(conn.getResponseCode() == 200){
InputStream is = conn.getInputStream();
return parserHeaderNews(is);
} return null;
} public List<HeaderNew> parserHeaderNews(InputStream is) throws Exception {
List<HeaderNew> headerNews = null;
HeaderNew headerNew = null; XmlPullParser parser = Xml.newPullParser(); parser.setInput(is,"UTF-8"); int eventType = parser.getEventType(); while(eventType != XmlPullParser.END_DOCUMENT){
switch(eventType){
case XmlPullParser.START_TAG:
if("HeaderNews".equals(parser.getName())){
headerNews = new ArrayList<HeaderNew>();
}else if("HeaderNew".equals(parser.getName())){
headerNew = new HeaderNew();
}else if("image".equals(parser.getName())){
headerNew.setImage(parser.nextText());
}else if("title".equals(parser.getName())){
headerNew.setTitle(parser.nextText());
}else if("content".equals(parser.getName())){
headerNew.setContent(parser.nextText());
}else if("count".equals(parser.getName())){
headerNew.setCount(parser.nextText());
}
break;
case XmlPullParser.END_TAG:
if("HeaderNew".equals(parser.getName())){
headerNews.add(headerNew);
headerNew = null;
}
break;
default:
break;
} eventType = parser.next();
} return headerNews;
}
4、抓取JSON格式的数据
抓取JSON格式的数据是以抓取网页源码为基础的。
public List<HeaderNew> getHeaderNewsFromJSON(Context context) throws Exception{
List<HeaderNew> headerNews = new ArrayList<HeaderNew>(); String path = context.getResources().getString(R.string.serverurl_json); URL url = new URL(path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET");
conn.setConnectTimeout(5000);
if(conn.getResponseCode() == 200){
InputStream is = conn.getInputStream(); ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len = 0;
while((len = is.read(buffer)) != -1){
bos.write(buffer,0,len);
}
String json = bos.toString(); JSONArray jsonArray = new JSONArray(json); for(int i = 0 ; i < jsonArray.length() ; ++i){
JSONObject jsonObject = (JSONObject) jsonArray.get(i);
HeaderNew headerNew = new HeaderNew(); headerNew.setImage(jsonObject.getString("image"));
headerNew.setTitle(jsonObject.getString("title"));
headerNew.setContent(jsonObject.getString("content"));
headerNew.setCount(jsonObject.getString("count")); headerNews.add(headerNew);
}
} return headerNews;
}
5、抓取Xml形式的数据与抓取JSON形式的数据的区别
构建时的区别:
1)Xml形式的数据
服务器端直接返回数据集合,由JSP来构建XML形式的数据
代码如下:
servlet:
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { HeaderNewsService service = new HeaderNewsService();
List<HeaderNew> headerNews = service.getHeaderNews(); request.setAttribute("headerNews", headerNews);
request.getRequestDispatcher("/WEB-INF/page/headernewsxml1.jsp").forward(request, response);
}
jsp:
<?xml version="1.0" encoding="UTF-8"?>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page contentType="text/html; charset=utf-8" %>
<HeaderNews>
<c:forEach items="${headerNews}" var="headerNew">
<HeaderNew>
<image>${headerNew.image }</image>
<title>${headerNew.title }</title>
<content>${headerNew.content}</content>
<count>${headerNew.count}</count>
</HeaderNew>
</c:forEach>
</HeaderNews>
2)JSON形式的数据
在服务器端构造好JSON格式的数据。JSP页面直接显示即可。
代码如下:
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { HeaderNewsService service = new HeaderNewsService();
List<HeaderNew> headerNews = service.getHeaderNews();
StringBuilder sb = new StringBuilder("["); for(HeaderNew headerNew : headerNews){
sb.append("{");
sb.append("image:").append("\"").append(headerNew.getImage()).append("\"").append(",");
sb.append("title:").append("\"").append(headerNew.getTitle()).append("\"").append(",");
sb.append("content:").append("\"").append(headerNew.getContent()).append("\"").append(",");
sb.append("count:").append("\"").append(headerNew.getCount()).append("\"");
sb.append("}");
sb.append(",");
}
sb.deleteCharAt(sb.length() - 1);
sb.append("]"); String json = sb.toString();
request.setAttribute("json",json);
request.getRequestDispatcher("/WEB-INF/page/headernewsjson.jsp").forward(request,response);
}
JSP:
<%@ page contentType="text/html; charset=UTF-8" %>
${json}
附上JSON数据的格式:
[{ a : b , c : d } , {.....}]
android端从服务器抓取的几种常见的数据的处理方式的更多相关文章
- android端向服务器提交请求的几种方式
1.GET方式 其实GET方式说白了,就是拼接字符串..最后拼成的字符串的格式是: path ? username= ....& password= ...... public boolea ...
- [python]初试页面抓取——抓取沪深股市交易龙虎榜数据
[python]抓取沪深股市交易龙虎榜数据 python 3.5.0下运行 没做自动建立files文件夹,需要手动在py文件目录下建立files文件夹后运行 #coding=utf-8 import ...
- 抓取“矢量”的实时交通流量数据
1. 引言 最近老师有一个需求,就是想要抓取实时的矢量交通流量数据来做分析,类似于百度地图,高德地图的"实时路况"那种.平时的网络抓取工作一般是抓取网页上现成的数据,但是交通流量数 ...
- Java服务器对外提供接口以及Android端向服务器请求数据
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/5056780.html 讲解下java服务器是如何对移动终端提供接口的,以什么数据格式提供出去,移动端又是怎么 ...
- Android 7.0解决抓取不到https请求的问题
问题:Android7.0系统,使用fiddler不能抓取https请求 解决方法: 1.在源码res目录下新建xml目录,增加network_security_config.xml文件 (工程名/ ...
- Android移动网络如何抓取数据包
1)下载tcpdump工具 tcpdump(dump the traffic on a network)是Linux中强大的网络数据采集分析工具之一,可以将网络中传送的数据包头完全截获下来提供分析.它 ...
- Android MaoZhuaWeiBo开发Service抓取个人信息-2
前面把基本的东西讲完了,之后就是数据的获取和解析显示出来了,那接下来我们就负责抓取数据的这块吧,首先我们须要 在清单文件中载入服务和活动 加入:. <activity android:name= ...
- Charles安装破解、抓取https请求及常见问题解决方法
现在基本大部分网站都使用了https,所以要想抓到https的请求,首要任务是先有工具:charles.fiddler,先介绍下charles针对https请求的抓取方法,此方法兼容windows和m ...
- 如何抓取基于https协议的webservice数据包
方法一:基于Fiddler2等第三方工具(需要在Java端禁用SSL安全检查) 原文拷贝自http://blog.csdn.net/zmxj/article/details/6327775,向原作者表 ...
随机推荐
- 基于FPGA的DW8051移植(三)
总结一下问题: 1) http://www.cnblogs.com/sepeng/p/4137405.html 基于FPGA的DW8051移植(一)里面用modelsim观测波形发现程序进入了ida ...
- 【HTTP 2】简介(Introduction)
前情提要 在上一篇文章<[HTTP 2.0] 序言>中,我们简要介绍了 HTTP 2 协议的概要和协议状态. 在本篇文章中,我们将会了解到 HTTP 2 协议简介(Introduction ...
- lucene 索引查看工具
luke 是 lucene 索引查看工具,基于 swing 开发的,是 lucene.solr.nutch 开发过程中不可或缺的工具.在测试搜索过程,进程出现搜不到东西或者搜到的东西不是想要的结果时, ...
- ZooKeeper - Perl bindings for Apache ZooKeeper Perl绑定用于 Apache ZooKeeper
ZooKeeper - Perl bindings for Apache ZooKeeper Perl绑定用于 Apache ZooKeeper 监控 master/slave 需要使用zk的临时节点 ...
- XML 的实体引用
实体引用 在 XML 中,一些字符拥有特殊的意义. 如果你把字符 "<" 放在 XML 元素中,会发生错误,这是因为解析器会把它当作新元素的开始. 这样会产生 XML 错误: ...
- Winform ErrorProvider控件使用
要实现的功能:判断第一个文本框中输入的是不是字符 “a”. 最终效果: *当输入的不是a,控件旁会显示错误图标.当输入的是a,则错误图标会消失. 首先添加ErrorProvider控件. 代码: pr ...
- iOS 使用SBJSON创建和解析JSON
原文地址:http://blog.csdn.net/gf771115/article/details/7718403 //创建JSON NSDictionary *dictonary = [[NSMu ...
- 知识点1-4:ASP.NET MVC的好处
ASP.NET MVC解决了ASP.NET Web Form的许多缺点.当在.NET平台上开发新的应用程序时,这使ASP.NET MVC成为一种更好的选择. 1. 对HTML的完全控制 2. 对URL ...
- WCF技术剖析之二十六:如何导出WCF服务的元数据(Metadata)[实现篇]
原文:WCF技术剖析之二十六:如何导出WCF服务的元数据(Metadata)[实现篇] 元数据的导出就是实现从ServiceEndpoint对象向MetadataSet对象转换的过程,在WCF元数据框 ...
- mysql启动的四种方式
mysql的四种启动方式: .mysqld 启动mysql服务器:./mysqld --defaults-file=/etc/my.cnf --user=root 客户端连接: mysql --def ...