使用HttpURLConnection类不仅可以向WebService发送字符串,还可以发送序列化的java对象,实现Android手机和服务器之间的数据交互。

Android端代码:

     public String SendDataByPost(String urlStr){
URL url = null;
String result="";//要返回的结果
try {
url=new URL(urlStr);
HttpURLConnection httpURLConnection= (HttpURLConnection) url.openConnection(); httpURLConnection.setConnectTimeout(2000);//设置连接超时时间,单位ms
httpURLConnection.setReadTimeout(2000);//设置读取超时时间,单位ms //设置是否向httpURLConnection输出,因为post请求参数要放在http正文内,所以要设置为true
httpURLConnection.setDoOutput(true); //设置是否从httpURLConnection读入,默认是false
httpURLConnection.setDoInput(true); //POST请求不能用缓存,设置为false
httpURLConnection.setUseCaches(false); //传送的内容是可序列化的
//如果不设置此项,传送序列化对象时,当WEB服务默认的不是这种类型时,会抛出java.io.EOFException错误
httpURLConnection.setRequestProperty("Content-type","application/x-java-serialized-object"); //设置请求方法是POST
httpURLConnection.setRequestMethod("POST"); //连接服务器
httpURLConnection.connect(); //getOutputStream会隐含调用connect(),所以不用写上述的httpURLConnection.connect()也行。
//得到httpURLConnection的输出流
OutputStream os= httpURLConnection.getOutputStream(); //构建输出流对象,以实现输出序列化的对象
ObjectOutputStream objOut=new ObjectOutputStream(os); //dataPost类是自定义的数据交互对象,只有两个成员变量
dataPost data= new dataPost("Tom",null); //向对象输出流写出数据,这些数据将存到内存缓冲区中
objOut.writeObject(data); //刷新对象输出流,将字节全部写入输出流中
objOut.flush(); //关闭流对象
objOut.close();
os.close(); //将内存缓冲区中封装好的完整的HTTP请求电文发送到服务端,并获取访问状态
if(HttpURLConnection.HTTP_OK==httpURLConnection.getResponseCode()){ //得到httpURLConnection的输入流,这里面包含服务器返回来的java对象
InputStream in=httpURLConnection.getInputStream(); //构建对象输入流,使用readObject()方法取出输入流中的java对象
ObjectInputStream inObj=new ObjectInputStream(in);
data= (dataPost) inObj.readObject(); //取出对象里面的数据
result=data.password; //输出日志,在控制台可以看到接收到的数据
Log.w("HTTP",result+" :by post"); //关闭创建的流
in.close();
inObj.close();
}else{
Log.w("HTTP","Connction failed"+httpURLConnection.getResponseCode());
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
 package com.example.com.example.data;

 import java.io.Serializable;

 //实现Serializable接口,使dataPost可序列化。
public class dataPost implements Serializable { /*指定序列化版本号,保证序列化版本的一致性。在服务器端,JVM会把传来的字节流的
serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认
为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。*/
private static final long serialVersionUID = 1L; String name;
String password;
public dataPost(String name, String password) {
this.name = name;
this.password = password;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} }

服务端程序:

 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

         ServletInputStream in=request.getInputStream();
dataPost datap = null;
ObjectInputStream obj=new ObjectInputStream(in);
try {
datap= (dataPost) obj.readObject();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}finally{
obj.close();
}
response.setContentType("application/x-java-serialized-object");
OutputStream out=response.getOutputStream();
ObjectOutputStream outObj=new ObjectOutputStream(out);
datap.setPassword("9964646");
outObj.writeObject(datap);
outObj.flush();
outObj.close();
}

注意事项:

1、客户端url如果有中文会出现乱码,需要对url进行编码。

例如:

 String url="你好";
URI uri=new URI(url,false,"utf-8");
url=uri.toString();

2、在Android主程序中调用SendDataByPost()方法时,要重新开一个线程,否则会阻塞主线程。

 new Thread(new Runnable() {
@Override
public void run() {
HTTPURLConnectionGETData getData = new HTTPURLConnectionGETData();
String result=getData.SendStringDataByPost(serverIP1);
if("".equals(result)){
}else{
Log.i("HTTP",result);
}
}
}).start();

3、Android端dataPost类的包名和server端dataPost的包名必须一致,否则就会出现找不到该类的异常。

java.lang.ClassNotFoundException: com.example.com.example.data.dataPost

at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1333)

4、Android端dataPost类的包名和server端dataPost的序列化版本必须一致,否则会报出serialVersionUID不同的错误。

Servlet.service() for servlet [com.test.stream.testStream] in context with path [/campus2] threw exception

java.io.InvalidClassException: com.example.com.example.data.dataPost; local class incompatible:

stream classdesc serialVersionUID = -1197271749879367300, local class serialVersionUID = -3085829960977977003

解决方法:

在两端的dataPost类中显式的指定序列化版本号,一般通过添加private static final long serialVersionUID = 1L实现。

Android使用HttpURLConnection通过POST方式发送java序列化对象的更多相关文章

  1. Java 序列化 对象序列化和反序列化

    Java 序列化 对象序列化和反序列化 @author ixenos 对象序列化是什么 1.对象序列化就是把一个对象的状态转化成一个字节流. 我们可以把这样的字节流存储为一个文件,作为对这个对象的复制 ...

  2. java序列化对象 插入、查询、更新到数据库

    java序列化对象 插入.查询.更新到数据库 : 实现代码例如以下: import java.io.ByteArrayInputStream; import java.io.ByteArrayOutp ...

  3. Java 序列化对象工具类

    SerializationUtils.java package javax.utils; import java.io.ByteArrayInputStream; import java.io.Byt ...

  4. android NDK 实用学习(二)-java端对象成员赋值和获取对象成员值

    1,关于java端类及接口定义请参考: android NDK 实用学习-获取java端类及其类变量 2,对传过来的参数进行赋值: 对bool类型成员进行赋值  env->SetBooleanF ...

  5. Java序列化对象-字符串转换

    package com.test; import com.alibaba.fastjson.JSON; import org.junit.Test; import java.io.ByteArrayI ...

  6. Java序列化对象为字符串并将字符串反序列化为对象

    对象的序列化与反序列化其实就是将对象的状态保存下来,一般是保存到文件中,但是其实更常用的是将对象序列化为字符串保存到数据库中,然后在需要读取对象的情况下将字符串反序列化为对象.   可以序列化的类必须 ...

  7. java序列化对象为什么要定义serialversionUID值?

    SerialVersionUid,简言之,其目的是序列化对象版本控制,有关各版本反序列化时是否兼容.如果在新版本中这个值修改了,新版本就不兼容旧版本,反序列化时会抛出InvalidClassExcep ...

  8. Serializable详解(1):代码验证Java序列化与反序列化

    说明:本文为Serializable详解(1),最后两段内容在翻译上出现歧义(暂时未翻译),将在后续的Serializable(2)文中补充. 介绍:本文根据JDK英文文档翻译而成,本译文并非完全按照 ...

  9. java 序列化时排除指定属性

    java 序列化对象如何排除指定属性呢? java 中序列化对象有多种方式:struts2 ,jackson,json-lib (1)使用struts2 json插件 依赖的jar包:struts2- ...

随机推荐

  1. OpenGL超级宝典visual studio 2013开发环境配置,GLTools

    做三维重建需要用到OpenGL,开始看<OpenGL超级宝典>,新手第一步配置环境就折腾了一天,记录下环境的配置过程. <超级宝典>中的例子使用了GLEW,freeglut以及 ...

  2. Moon.Orm版本维护及下载(跟踪报道)

    提示:最下面有最新的下载地址  历史记录: ).-- :: 支持Mysql,Sqlserver(点击下载) ).2013年9月14日,代码重构,加入oracle.复合主键功能(点击下载) )--,为d ...

  3. 30分钟?不需要,轻松读懂IL

    先说说学IL有什么用,有人可能觉得这玩意平常写代码又用不上,学了有个卵用.到底有没有卵用呢,暂且也不说什么学了可以看看一些语法糖的实现,或对.net理解更深一点这些虚头巴脑的东西.最重要的理由就是一个 ...

  4. .NET设计模式(1):1.1 单例模式(Singleton Pattern)

    概述 单例模式就是保证在整个应用程序的生命周期中,在任何时刻,被指定的类只有一个实例,并为客户程序提供一个获取该实例的全局访问点. 单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单 ...

  5. VS2013设置护眼背景颜色

    打开VS2013 —> 工具 —> 选项 —> 环境 —> 字体和颜色 —> 选择显示项中的纯文本 —> 项目背景 —> 自定义—> 色调位85.饱和度 ...

  6. iOS--使用UIImageView进行GIF动图播放

    大家好,好久没有跟新了.其实也就昨天到今天的时间. 前言:实际上,GIF动图文件中包含了一组图片及其信息数组,这些信息数据记录着这一组图片中各张图片的播放时长等信息,我们可以将图片和这些信息或取出来, ...

  7. Lind.DDD.Repositories.Redis层介绍

    回到目录 之前已经发生了 大叔之前介绍过关于redis的文章,有缓存,队列,分布式pub/sub,数据集缓存以及仓储redis的实现等等,而今天在Lind.DDD的持久化组件里,redis当然也有一席 ...

  8. JMeter专题系列(五)检查点

    JMeter也有像LR中的检查点: JMeter里面的检查点通过添加断言来完成. 检查点:我们对用户名和密码进行了参数化,那么怎样来判断jmeter有没有正确调用t.dat里面的文件呢.当然,我们可以 ...

  9. SOA的浅析

    曾今SOA的概念犹如今日“云计算.大数据”一样,被炒得火热,不少企业便纷纷响应,并宣称会拥抱和实施SOA.而事实上,业界出现了两种极端:一种是由于各类文章和书籍关于SOA的描述往往太过抽象,再加上各大 ...

  10. karma的基础应用之与fis结合

    一.介绍 1. karma是单元测试运行框架,可以集成jasmine断言库,也支持babel. 2.fis是百度前端团队开源推出的前端工程化管理工具. 二.karma的基础应用 1.karma的基础a ...