在服务器与客户端之间通信,json数据是一种常用格式,本文主要在服务器端构建数据,在客户端接收显示,并且在listview上显示出来

服务器端的构建

简单的javabean与返回结果函数与插入函数略过

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html"); response.setCharacterEncoding("UTF-8"); PrintWriter out = response.getWriter(); List<MyShop> shops = JsonService.getListShop(); StringBuffer sb = new StringBuffer(); sb.append('['); for (MyShop shop : shops) { sb.append('{').append("\"name\":").append("\""+shop.getName()+"\"").append(",");
sb.append("\"detail\":").append("\""+shop.getDetail()+"\"").append(",");
sb.append("\"distance\":").append("\""+shop.getDistance()+"\"").append(",");
sb.append("\"address\":").append("\""+shop.getAddress()+"\"").append(",");
sb.append("\"popularity\":").append(shop.getPopularity());
sb.append('}').append(",");
} sb.deleteCharAt(sb.length() - 1); sb.append(']'); out.write(new String(sb)); out.flush(); out.close(); }

在浏览器中直接输入访问http://localhost:8080/AppServer/JsonServlet

可得

可以在服务器端直接查看json数据

客户端接收与解析json数据

public class JsonParse {

    /**

     * 解析Json数据

     *

     * @param urlPath

     * @return mlists

     * @throws Exception

     */

    public static List<MyShop> getListShop(String urlPath) throws Exception {

            List<MyShop> mlists = new ArrayList<MyShop>();

            byte[] data = readParse(urlPath);

            JSONArray array = new JSONArray(new String(data));

            for (int i = 0; i < array.length(); i++) {

                    JSONObject item = array.getJSONObject(i);

                    String name = item.getString("name");
String detail = item.getString("detail");
String distance = item.getString("distance"); String popularity = item.getString("popularity"); String address = item.getString("address"); mlists.add(new MyShop(name, detail, distance,address,popularity)); } return mlists; } /** * 从指定的url中获取字节数组 * * @param urlPath * @return 字节数组 * @throws Exception */ public static byte[] readParse(String urlPath) throws Exception { ByteArrayOutputStream outStream = new ByteArrayOutputStream(); byte[] data = new byte[1024]; int len = 0; URL url = new URL(urlPath); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); InputStream inStream = conn.getInputStream(); while ((len = inStream.read(data)) != -1) { outStream.write(data, 0, len); } inStream.close(); return outStream.toByteArray(); } }

在activity中开启子线程来接收服务器数据

new Thread(new Runnable() {

            private String tag;

            @Override
public void run() {
// TODO Auto-generated method stub
//获得新闻集合 List<MyShop> shopList = null;
try {
shopList = JsonParse.getListShop("http://192.168.247.1:8080/AppServer/JsonServlet");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Log.i(tag, "在RUN中LIST长度为"+shopList.size());
Message msg=new Message();
if(shopList!=null)
{
msg.what=SUCCESS;
msg.obj=shopList; }else
{
msg.what=FAILED;
}
handler.sendMessage(msg);
Log.i(tag, "***********T长度为"+shopList.size()); }
}).start();

消息处理器

 //消息处理器
private Handler handler=new Handler(){ /**
* 接收消息
*/
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub String tag = null;
switch (msg.what) {
case SUCCESS: //访问成功,有数据 //绑定数据
Log.i(tag,"%%%%%%%%%%到达了消息处理器");
myshoplist=(List<MyShop>) msg.obj;
Log.i(tag, "handleMessage中数据newInfoList长度为"+myshoplist.size());
NearAdapter adapter=new NearAdapter();
Log.i(tag, "有没有到达ADAPTER"+adapter.getCount());
showList.setAdapter(adapter); break; case FAILED: //访问失败
Toast.makeText(ChooseMer.this, "当前网络崩溃了", 0).show();
break; default:
break;
} } };

配置适配器

public class NearAdapter extends BaseAdapter {

        @Override
public int getCount() {
// TODO Auto-generated method stub
return myshoplist.size();
} @Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return null;
} @Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return 0;
} @Override
public View getView(int position, View convertView, ViewGroup parent) { if (convertView == null) {
LayoutInflater inflater = LayoutInflater
.from(ChooseMer.this);
convertView = inflater.inflate(R.layout.nearby_list_item, null);
init(convertView,position);
} return convertView;
} public void init(View convertView,int position) {
hold.name = (TextView) convertView
.findViewById(R.id.nearby_item_name);
MyShop shop=myshoplist.get(position);
hold.name.setText(shop.getName());
hold.local = (TextView) convertView
.findViewById(R.id.nearby_item_local);
hold.local.setText(shop.getDetail());
hold.dis1 = (TextView) convertView
.findViewById(R.id.nearby_item_dis1);
hold.dis1.setText(shop.getDistance());
hold.dis2 = (TextView) convertView
.findViewById(R.id.nearby_item_dis2);
hold.dis2.setText(shop.getAddress());
hold.dis3 = (TextView) convertView
.findViewById(R.id.nearby_item_dis3);
hold.dis3.setText(shop.getPopularity());
}
}

配置完成,效果如下

Android客户端与服务器之间传递json数据的更多相关文章

  1. 使用HttpURLConnection实现在android客户端和服务器之间传递对象

    一般情况下,客户端和服务端的数据交互都是使用json和XML,相比于XML,json更加轻量级,并且省流量,但是,无论我们用json还是用xml,都需要我们先将数据封装成json字符串或者是一个xml ...

  2. 序列化和反序列化在浏览器和 Web 服务器之间传递的数据、加密解密

    js中数组不能传递到后台,需进行json序列化: var data = new Array(); data.push({para1:name,para2:answer}); string data = ...

  3. Android:客户端和服务器之间传输数据加密

    Android客户端与服务器进行数据传输时,一般会涉及到两类数据的加密情况,一类是只有创建者才能知道的数据,比如密码:另一类是其他比较重要的,但是可以逆向解密的数据. 第一类:密码类的数据,为了让用户 ...

  4. Android Fragment之间传递List数据

    要说的是在两个Fragment之间传递List数据,比如有个List<User>,以及传递字符串数据,比如testId,该如何从FragmentA传递到FragmentB呢? 下面这个例子 ...

  5. 利用AXIS2传递JSON数据

    Axis2是目前比较流行的WebService引擎.WebService被应用在很多不同的场景.例如,可以使用WebService来发布服务端 Java类的方法,以便使用不同的客户端进行调用.这样可以 ...

  6. Android客户端与服务器

    就是普通的服务器端编程,还不用写界面,其实还比服务器编程简单一些.跟J2EE一样的服务器,你android这一方面只要用json或者gson直接拿数据,后台的话用tomcat接受请求操作数据,功能不复 ...

  7. Android客户端与服务器交互方式-小结

    最近的Android项目开发过程中一个问题困扰自己很长时间,Android客户端与服务器交互有几种方式,最常见的就是webservices和json.要在Android手机客户端与pc服务器交互,需要 ...

  8. Ajax(form表单文件上传、请求头之contentType、Ajax传递json数据、Ajax文件上传)

    form表单文件上传 上菜 file_put.html <form action="" method="post" enctype="multi ...

  9. Android学习总结——Activity之间传递参数

    核心内容:一.在 Activity 之间传递简单数据二.在 Activity 之间传递复杂数据 三.在 Activity 之间传递自定义值对象   软件环境:Android Studio   一.在 ...

随机推荐

  1. hihocoder #1285 智力竞赛

    传送门 总结: 1.仔细读题 2.仔细分析复杂度 3.不要想当然,乱下结论 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi.小Ho还有被小Hi强拉来的小Z,准备组队 ...

  2. app工程构成

    1)工程配置文件: 2)源代码: 3)资源文件.

  3. Centos6.4下Yum命令安装Mysql数据库及配置

    如果要在Linux上做j2ee开发,首先得搭建好j2ee的开发环境,包括了jdk.tomcat.eclipse的安装(这个在之前的一篇随笔中已经有详细讲解了 如果要开发web项目,我们当然可以安装一个 ...

  4. stl 迭代器(了解)

    STL 主要是由 containers(容器),iterators(迭代器)和 algorithms(算法)的 templates(模板)构成的. 对应于它们所支持的操作,共有五种 iterators ...

  5. spring bean实例化方式

    注意:xml配置中bean节点下scope属性默认值为singleton(单例),在需要多例的情况下需要配置成prototype spring提供三种实例化方式:默认构造.静态工厂.实例工厂 一.默认 ...

  6. java可变参数例子:求学生成绩信息,不确定课程数

    可变参数特点: 1)...只能出现在参数列表的最后2)...位于变量类型和变量名之间3)调用可变参数的方法时,编译器为该可变参数隐含创建一个数组,在方法体中以数组的形式访问可变参数 //可变参数也可用 ...

  7. Python socket编程之六:多窗口的应用

    import struct import sqlalchemy import pandas import matplotlib.pyplot as Plot from matplotlib.finan ...

  8. linux vsftpd搭建

    1.yum install vsftpd; 2.关闭SELinux的方法:修改/etc/selinux/config文件中的SELINUX="" 为 disabled ,然后重启 ...

  9. iOS学习笔记—ViewController/生命周期

    ViewController是iOS应用程序中重要的部分,是应用程序数据和视图之间的重要桥梁,ViewController管理应用中的众多视图.iOS的SDK中提供很多原生ViewController ...

  10. ctags 的最简单使用

    vim插件ctags的安装和使用 2013-11-19 20:47 17109人阅读 评论(0) 收藏 举报  分类: 开发工具(3)  linux编程(9)  c/c++编程(11)  版权声明:本 ...