智能机器人“小昆”的实现(三)实体类的实现
2015-10-02 19:33
375 查看
在上一篇文章中,我们实现了获取服务器返回数据的工具类。没有读过的朋友可以点击下面链接:
/article/6123600.html
这一篇文章要在上一篇的基础上,实现两个重要的实体类,一个是ChatMsg,用来封装数据从而实现标准的消息格式;一个是ResultMsg,用来封装从服务器端返回的数据。
一、准备工作
在这里,解析json字符串,我们打算使用第三方包GSON。首先点击下面的地址,下载该包。
http://code.google.com/p/google-gson/downloads/list
下面完成后解压,将gson-2.2.4添加到项目的libs目录下即可。
二、编写实体类
首先编写ResultMsg类。为什么需要这样一个类呢?这是因为我们打算从服务器端返回的数据中提取字段code和字段text的包含的信息。因此我们编写类ResultMsg,它有两个String成员变量,分别就是code 和text。这样子,使用gson解析数据,就会直接将服务器端的数据截取code和text两个字段信息映射为一个ResultMsg对象,即封装为一个ResultMsg对象。 好了,ResultMsg的代码很简单,如下:
然后再编写ChatMsg类。那么为什么需要这样一个类呢?其实就是为了生成我们的标准的消息。从前面的运行效果的界面可以看到,一个标准的消息,应该包括消息内容,消息的时间,消息的类型(是自己发送的消息还是从服务器端返回的消息)。看我们的代码吧,如下:
三、HttpUtil类的第二次编写
之前在HttpUtil中,我们只实现了获取服务器返回的数据的方法(即doGet()方法)。它获取的是一个json类型的字符串。下面我们要实现解析这个字符串,并且顺便将其封装为一个标准的消息。HttpUtil修改如下:
好了,至此,我们的项目算是成功一半了。从服务器端获取数据并封装为标准消息的工作我们已经完成了。不过现在我们完成的都是看不见的工作,在下一篇中,我们来实现可以看得见的工作吧。
/article/6123600.html
这一篇文章要在上一篇的基础上,实现两个重要的实体类,一个是ChatMsg,用来封装数据从而实现标准的消息格式;一个是ResultMsg,用来封装从服务器端返回的数据。
一、准备工作
在这里,解析json字符串,我们打算使用第三方包GSON。首先点击下面的地址,下载该包。
http://code.google.com/p/google-gson/downloads/list
下面完成后解压,将gson-2.2.4添加到项目的libs目录下即可。
二、编写实体类
首先编写ResultMsg类。为什么需要这样一个类呢?这是因为我们打算从服务器端返回的数据中提取字段code和字段text的包含的信息。因此我们编写类ResultMsg,它有两个String成员变量,分别就是code 和text。这样子,使用gson解析数据,就会直接将服务器端的数据截取code和text两个字段信息映射为一个ResultMsg对象,即封装为一个ResultMsg对象。 好了,ResultMsg的代码很简单,如下:
package com.fuly.kun.bean; //用来封装从服务器端返回的数据 //从服务器端返回的数据主要包括code和Text字段 public class ResultMsg { private String code; private String text; public String getCode() { return code; } public void setCode(String code) { this.code = code; } public String getText() { return text; } public void setText(String text) { this.text = text; } }
然后再编写ChatMsg类。那么为什么需要这样一个类呢?其实就是为了生成我们的标准的消息。从前面的运行效果的界面可以看到,一个标准的消息,应该包括消息内容,消息的时间,消息的类型(是自己发送的消息还是从服务器端返回的消息)。看我们的代码吧,如下:
package com.fuly.kun.bean; import java.util.Date; //用来把从服务器端获得的数据或者我们发送的消息变成一个标准的消息格式 //应该包括消息文本,获取的时间,以及消息的类型(是从服务器端获取的还是我们自己发送的) public class ChatMsg { private String msg;//消息 private Date date;//日期 private Type type;//消息类型 public enum Type{ INPUT,OUTPUT } public ChatMsg() { } public ChatMsg(String msg, Date date, Type type) { this.msg = msg; this.date = date; this.type = type; } public String getMsg() { return msg; } public void setMsg(String msg) { this.msg = msg; } public Date getDate() { return date; } public void setDate(Date date) { this.date = date; } public Type getType() { return type; } public void setType(Type type) { this.type = type; } }
三、HttpUtil类的第二次编写
之前在HttpUtil中,我们只实现了获取服务器返回的数据的方法(即doGet()方法)。它获取的是一个json类型的字符串。下面我们要实现解析这个字符串,并且顺便将其封装为一个标准的消息。HttpUtil修改如下:
package com.fuly.kun.util; import java.io.BufferedReader; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.UnsupportedEncodingException; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.ProtocolException; import java.net.URL; import java.net.URLEncoder; import java.util.Date; import android.util.Log; import com.fuly.kun.bean.ChatMsg; import com.fuly.kun.bean.ChatMsg.Type; import com.fuly.kun.bean.ResultMsg; import com.google.gson.Gson; import com.google.gson.JsonSyntaxException; //该类用来向服务器发送消息以及处理从服务器返回的数据 public class HttpUtil { //该方法用来解析从服务器端获得的数据,封装为ChatMsgMsg对象 public static ChatMsg getResultMsg(String jsonData){ ChatMsg cm = new ChatMsg(); ResultMsg rm = null; try { //下面两句代码已经完成了json数据的提取和封装 Gson gson = new Gson(); rm = gson.fromJson(jsonData, ResultMsg.class); cm.setMsg(rm.getText().toString()); } catch (Exception e) { cm.setMsg("服务器异常,请重新尝试"); } cm.setDate(new Date()); cm.setType(Type.OUTPUT);//消息类型为OUTPUT,即从服务器端返回的 return cm; } //该方法用来处理从服务器返回的数据 public static String doGet(String msg){ //获取相应的网址 URL msgUrl = setMsgParam(msg); HttpURLConnection connection = null; try { //然后开始和服务器建立连接 connection = (HttpURLConnection) msgUrl.openConnection(); connection.setRequestMethod("GET"); connection.setConnectTimeout(5000); connection.setReadTimeout(5000); } catch (ProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } InputStream in = null; try { //下面对获得输入流进行读取 in = connection.getInputStream(); BufferedReader reader = new BufferedReader(new InputStreamReader(in)); StringBuilder response = new StringBuilder(); String line ; while((line = reader.readLine())!= null){ response.append(line); } String str = response.toString(); //因为发现从服务器端返回的json数据中,经常带有特殊字符<br> //所以在这里特地将该特殊字符替换为转义字符\n str = str.replace("<br>", "\n"); return str; } catch (IOException e) { e.printStackTrace(); }finally{ if(connection != null){ connection.disconnect(); } if(in != null){ try { in.close(); } catch (IOException e) { e.printStackTrace(); } } } return null; } //该方法用来返回相应的网址 private static URL setMsgParam(String msg) { //注意此处应写你自己的api key String APIKEY = "761b4f79ebdf8b26d0bf7e0c816b32b4"; try { //将编码格式设置为utf-8,千万别忘记这一步 String mMsg = URLEncoder.encode(msg, "utf-8"); String getURL = "http://www.tuling123.com/openapi/api?key=" + APIKEY + "&info=" + mMsg; URL getUrl = new URL(getURL); return getUrl; } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (MalformedURLException e) { e.printStackTrace(); } return null; } }
好了,至此,我们的项目算是成功一半了。从服务器端获取数据并封装为标准消息的工作我们已经完成了。不过现在我们完成的都是看不见的工作,在下一篇中,我们来实现可以看得见的工作吧。
相关文章推荐
- 关于继承,动态绑定,静态绑定
- HDU 5202 Rikka with string
- nmi watchdog
- 网页/微信中的腾讯视频下载方法
- bzoj 1162 network
- Codeforces 85B. Embassy Queue【段树、馋】
- java类加载机制
- PHP实现邮件的自动发送
- Android Socket编程实例
- 用jquery实现全选/全部选功能(jquery-1.9.x 版本以上),使用 prop 属性
- LeetCode题解:Binary Tree Inorder Traversal
- scu oj 4443
- pat1011World Cup Betting (20)
- 还是要动手写博客
- CentOS构造SNMP
- [Sqlite]-->Java采用jdbc联系Sqlite各种特定的工艺数据库的数据操作
- 我眼中的科研
- LeetCode题解:Restore IP Addresses
- HttpClient实现网络访问详解1
- Hiho 1232 北京网络赛 F Couple Trees