AsyncHttpClient来完成网页源代码的显示功能,json数据在服务器端的读取还有安卓上的读取

一、使用AsyncHttpClient来完成网页源代码的显示功能:

首先。我们引入

步骤:

1.添加网络权限

2.判断网页地址是否为空

3.不为空的情况下创建客户端对象

4.处理get/post请求

5.如果成功的话,设置显示内容的值

a) 获取文件响应编码类型(保证不乱码)

i. 遍历头部信息取出contentType_value的值

ii. 定义服务器缺省编码方式

iii.  处理contentType_value来获取编码方式

1. contentType_value是否有“=”

2. contentType_value是否为空

b) 根据服务端返回的编码给显示内容设置值

[java] view plaincopy

  1. package com.example.android_htmlcode;
  2. import java.io.UnsupportedEncodingException;
  3. import org.apache.http.Header;
  4. import android.app.Activity;
  5. import android.os.Bundle;
  6. import android.text.TextUtils;
  7. import android.view.View;
  8. import android.widget.EditText;
  9. import android.widget.TextView;
  10. import android.widget.Toast;
  11. import com.loopj.android.http.AsyncHttpClient;
  12. import com.loopj.android.http.AsyncHttpResponseHandler;
  13. public class MainActivity extends Activity {
  14. private EditText et_url;
  15. private TextView tv_url;
  16. @Override
  17. protected void onCreate(Bundle savedInstanceState) {
  18. super.onCreate(savedInstanceState);
  19. // 设置显示视图
  20. setContentView(R.layout.activity_main);
  21. et_url = (EditText) findViewById(R.id.et_url);
  22. tv_url = (TextView) findViewById(R.id.tv_info);
  23. }
  24. // android:onClick="sendHttpUil
  25. public void sendHttpUil(View v) {
  26. int id = v.getId();
  27. switch (id) {
  28. case R.id.btn_send:
  29. String url = et_url.getText().toString();
  30. // 判断网页地址是否为空
  31. if (TextUtils.isEmpty(url)) {
  32. Toast.makeText(this, "网页地址不能为空", 0).show();
  33. } else {
  34. // 创建客户端对象
  35. AsyncHttpClient client = new AsyncHttpClient();
  36. // 处理get/post请求
  37. client.get(url, new AsyncHttpResponseHandler() {
  38. @Override
  39. public void onSuccess(int statusCode, Header[] headers,
  40. byte[] responseBody) {
  41. super.onSuccess(statusCode, headers, responseBody);
  42. // 获取文件响应类型
  43. String contentType_value = null;
  44. // 遍历头部信息
  45. for (Header header : headers) {
  46. // 获取contentType_value的头部信息
  47. if (header.getName().equals("Content-Type")) {
  48. // 获取他的value值
  49. contentType_value = header.getValue();
  50. }
  51. }
  52. // 定义服务器端缺省的编码方式
  53. String default_charset = "UTF-8";
  54. // 处理contentType_value来获取编码方式
  55. // 判断是否为null
  56. if (contentType_value != null) {
  57. // 判断是否有=字符
  58. if (contentType_value.contains("=")) {
  59. // 获取=字符位置
  60. int index = contentType_value.indexOf("=");
  61. // 从=所在位置的下一个字符开始截取,返回服务器端的编码
  62. default_charset = contentType_value.substring(
  63. index + 1, contentType_value.length());
  64. } else {
  65. String result = new String(responseBody);
  66. default_charset = getCharSet(result);
  67. }
  68. } else {
  69. String result = new String(responseBody);
  70. default_charset = getCharSet(result);
  71. }
  72. Toast.makeText(MainActivity.this,
  73. "编码是:" + default_charset, 0).show();
  74. if (statusCode == 200) {
  75. try {
  76. tv_url.setText(new String(responseBody,
  77. default_charset));
  78. } catch (UnsupportedEncodingException e) {
  79. // TODO Auto-generated catch block
  80. e.printStackTrace();
  81. }
  82. }
  83. }
  84. /**
  85. * 获取网页源代码中默认的编码
  86. *
  87. * @param result
  88. * @return
  89. */
  90. public String getCharSet(String result) {
  91. String defaultCharset = null;
  92. // <mate http-equiv="Content-Type"
  93. // content="text/html; charset=GBK" /> //html4
  94. // <mate charset="UTF-8">
  95. if (result != null) {
  96. if (result
  97. .contains("content=\"text/html; charset=GBK\"")) {
  98. defaultCharset = "GBK";
  99. } else if (result
  100. .contains("content=\"text/html; charset=UTF-8\"")) {
  101. defaultCharset = "UTF-8";
  102. } else if (result
  103. .contains("content=\"text/html; charset=GB2312\"")) {
  104. defaultCharset = "GB2312";
  105. } else if (result.contains("charset=\"UTF-8\"")) {
  106. defaultCharset = "UTF-8";
  107. } else if (result.contains("charset=\"UTF-8\"")) {
  108. defaultCharset = "GBK";
  109. }
  110. }
  111. return defaultCharset;
  112. }
  113. });
  114. }
  115. break;
  116. default:
  117. break;
  118. }
  119. }
  120. }

二、通过开源框架获取JSON数据:

[java] view plaincopy

  1. package com.example.android_json;
  2. import org.apache.http.Header;
  3. import org.json.JSONArray;
  4. import org.json.JSONException;
  5. import org.json.JSONObject;
  6. import com.loopj.android.http.AsyncHttpClient;
  7. import com.loopj.android.http.JsonHttpResponseHandler;
  8. import android.os.Bundle;
  9. import android.app.Activity;
  10. import android.view.Menu;
  11. import android.widget.Toast;
  12. public class MainActivity extends Activity {
  13. @Override
  14. protected void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.activity_main);
  17. // http://172.16.237.200:8080/video/JsonServlet
  18. initData();
  19. }
  20. private void initData() {
  21. // 创建客户端对象
  22. AsyncHttpClient client = new AsyncHttpClient();
  23. String url = "http://172.16.237.200:8080/video/JsonServlet";
  24. Toast.makeText(this, "发送请求到服务器", 0).show();
  25. client.get(url, new JsonHttpResponseHandler() {
  26. //返回JSONObject对象|JSONOArray对象
  27. @Override
  28. public void onSuccess(int statusCode, Header[] headers,
  29. JSONArray response) {
  30. // TODO Auto-generated method stub
  31. super.onSuccess(statusCode, headers, response);
  32. if (statusCode == 200) {
  33. //遍历json数组
  34. for (int i = 0; i < response.length(); i++) {
  35. try {
  36. // 获取具体的一个JSONObject对象
  37. JSONObject obj = response.getJSONObject(i);
  38. //JSONObject对象get(“属性名”),getString(“属性名”),getInt(“属性名”)等方法来获取指定属性名的值
  39. System.out.println("序号" + obj.getString("id")
  40. + "--------姓名:" + obj.getString("name")
  41. + "--------密码:" + obj.getString("pass")
  42. + "--------其他:" + obj.getString("pass"));
  43. } catch (JSONException e) {
  44. // TODO Auto-generated catch block
  45. e.printStackTrace();
  46. }
  47. }
  48. }
  49. }
  50. });
  51. }
  52. }

常见错误分析:当遍历json数组时,若没有对于json数据就会报错,例如:(部分代码整理源于赵雅智女士的)

AsyncHttpClient来完成网页源代码的显示功能,json数据在服务器端的读取还有安卓上的读取

时间: 2024-08-11 01:35:32

AsyncHttpClient来完成网页源代码的显示功能,json数据在服务器端的读取还有安卓上的读取的相关文章

微信小程序如何把后台返回的多条json数据的时间戳转换为时间放到页面上 (微信小程序 时间戳转换为时间)

小程序端 在utils文件夹下的util.js写入 //时间戳转换时间   function toDate(number){   var n=number * 1000;   var date = new Date(n);   var Y = date.getFullYear() + '/';   var M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '/';   var D = date

嵌套JSON数据自动回写HTML网页

本文介绍解析来自MongoDB数据库的JSON嵌套字符串,按HTML界面元素自定义属性展现数据内容的解决方案及技术实现代码. HTML网页定义 <html> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <head></head> <body> <h1>表单展示数据回写测试 JavaScript</h

nutch+mysql gb2312网页源代码中文乱码

问题描述: 将nutch爬的网页源代码存在mysql中,网页编码为gb2312的网页中文乱码,其他编码暂未发现问题.因为nutch对爬下的网页源代码content不作任何处理,仅仅保存,而我的mysql编码设置的为utf-8,所以会显示乱码. 现在需要处理网页源代码,取出指定数据,那么java程序如何将gb2312中文乱码的网页源代码转化为非乱码. 解决: 其实采用ResultSet的getBytes方法即可. public void getResoucePage() throws Except

PHP如何接收json数据

以前一直在写一些网站,很少涉及到接口的东西.最近公司在做一个平台,需要往接口上发送json数据.闲话少叙,直接上干货. 在php中可以通过如下方式获取: file_get_contents("php://input"); 分析: php做网页的表单提交 早年网页表单的提交,都是用$_POST获取请求参数,实际上在http请求头中是用kv值的形式存在,如: php在接收到这种请求的时候,php底层系统会将这种字符串解析并存放进$_POST变量中,所以在php中就可以通过$_POST获取这

spring之json数据的接受和发送

配置spring对json的注解方式. <!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" > <property name="messageConverters"> <list > <ref bea

【Spring学习笔记-MVC-4】返回Json数据-方式2

摘要 本文讲解另外一种利用spring MVC返回json数据的方法. 前文回顾 在<[Spring学习笔记-MVC-3]返回Json数据-方式1>中介绍了通过: @ResponseBody声明返回值: 配置<mvc:annotation-driven />: 来返回json数据.效果如下:   ==>, 从上面的效果看,只能返回一个对象,不能返回多个对象,不能做到形如下图的返回结果, 存在局限性(可能可以返回多个,自己不知道如何实现). 下面介绍的方式2,利用spring

异步请求取得json数据

一.异步请求 在之前我们请求数据的时候都是整个页面全部刷新了一次,也就是每次请求都会重新请求所有的资源.但是在很多时候不需要页面全部刷新,仅仅是需要页面的局部数据刷新即可,此时需要发送异步请求来实现这种局部数据刷新的要求,异步请求简称 Ajax(Asynchronous Javascript And XML),在之前一般使用js 发送异步请求,请求的数据一般是xml,但是现在 json 出现之后就不使用xml 做为数据传输格式标准了.使用jQuery 发送异步请求,jq中的异步请求发送有很多方式

android应用开发_网络部分2——采用HttpURLConnection获取获取网页源代码

本文是android应用开发_网络部分1——采用HttpURLConnection获取网络图片的延续练习. 接下来,我们再来一个查看网页源代码的工程来加深了解. 布局上还是一个竖直排列的线性布局,一个edittext用于输入html路径,一个button,用于点击获取,一个textview用于显示. main.xml 1 <?xml version="1.0" encoding="utf-8"?> 2 <LinearLayout xmlns:and

安卓开发教程-实战网页源代码查看器,安卓程序员必备

本系列教程致力于可以快速的进行学习安卓开发,按照项目式的方法,通常一篇文章会做一个小程序.提高学习的兴趣. 一方面总结自己所得,另一方面可以通过自己的分享帮助更多学习的同仁. 因为知识的连贯性,推荐按照瞬息进行学习.目录链接:http://www.chengxiaoxiao.com/bozhu/1336.html 本教程由今日头条-做全栈攻城狮原创首发,转载请注明出处. 求兼职:请联系wx:aiquanzhan 页尾提供github源代码下载地址. 一.项目描述: 众所周知,组成网站的每个页面都