Java Socket实战之四:传输压缩对象

开发 后端
上一篇文章说到了用Java Socket来传输对象,但是在有些情况下比如网络环境不好或者对象比较大的情况下需要把数据对象进行压缩然后在传输,此时就需要压缩这些对象流,此时就可以GZIPInputStream和GZIPOutputStream来处理一下socket的InputStream和OutputStream。

上一篇文章说到了用Java Socket来传输对象,但是在有些情况下比如网络环境不好或者对象比较大的情况下需要把数据对象进行压缩然后在传输,此时就需要压缩这些对象流,此时就可以GZIPInputStream和GZIPOutputStream来处理一下socket的InputStream和OutputStream。

仍然需要一个实现了java.io.Serializable接口的简单Java对象:

  1. package com.googlecode.garbagecan.test.socket.sample4;  
  2.  
  3. public class User implements java.io.Serializable {  
  4.     private static final long serialVersionUID = 1L;  
  5.     private String name;  
  6.     private String password;  
  7.  
  8.     public User() {  
  9.           
  10.     }  
  11.       
  12.     public User(String name, String password) {  
  13.         this.name = name;  
  14.         this.password = password;  
  15.     }  
  16.       
  17.     public String getName() {  
  18.         return name;  
  19.     }  
  20.  
  21.     public void setName(String name) {  
  22.         this.name = name;  
  23.     }  
  24.  
  25.     public String getPassword() {  
  26.         return password;  
  27.     }  
  28.  
  29.     public void setPassword(String password) {  
  30.         this.password = password;  
  31.     }  
  32.       

在Server端使用,socket的InputStream首先被包装成GZIPInputStream,然后又被包装成ObjectInputStream,而socket的OutputStream首先被包装成GZIPOutputStream,然后又被包装成ObjectOutputStream,如下:

  1. package com.googlecode.garbagecan.test.socket.sample4;  
  2.  
  3. import java.io.IOException;  
  4. import java.io.ObjectInputStream;  
  5. import java.io.ObjectOutputStream;  
  6. import java.net.ServerSocket;  
  7. import java.net.Socket;  
  8. import java.util.logging.Level;  
  9. import java.util.logging.Logger;  
  10. import java.util.zip.GZIPInputStream;  
  11. import java.util.zip.GZIPOutputStream;  
  12.  
  13. public class MyServer {  
  14.  
  15.     private final static Logger logger = Logger.getLogger(MyServer.class.getName());  
  16.       
  17.     public static void main(String[] args) throws IOException {  
  18.         ServerSocket server = new ServerSocket(10000);  
  19.  
  20.         while (true) {  
  21.             Socket socket = server.accept();  
  22.             socket.setSoTimeout(10 * 1000);  
  23.             invoke(socket);  
  24.         }  
  25.     }  
  26.  
  27.     private static void invoke(final Socket socket) throws IOException {  
  28.         new Thread(new Runnable() {  
  29.             public void run() {  
  30.                 GZIPInputStream gzipis = null;  
  31.                 ObjectInputStream ois = null;  
  32.                 GZIPOutputStream gzipos = null;  
  33.                 ObjectOutputStream oos = null;  
  34.                   
  35.                 try {  
  36.                     gzipis = new GZIPInputStream(socket.getInputStream());  
  37.                     ois = new ObjectInputStream(gzipis);  
  38.                     gzipos = new GZIPOutputStream(socket.getOutputStream());  
  39.                     oos = new ObjectOutputStream(gzipos);  
  40.  
  41.                     Object obj = ois.readObject();  
  42.                     User user = (User)obj;  
  43.                     System.out.println("user: " + user.getName() + "/" + user.getPassword());  
  44.  
  45.                     user.setName(user.getName() + "_new");  
  46.                     user.setPassword(user.getPassword() + "_new");  
  47.  
  48.                     oos.writeObject(user);  
  49.                     oos.flush();  
  50.                     gzipos.finish();  
  51.                 } catch (IOException ex) {  
  52.                     logger.log(Level.SEVERE, null, ex);  
  53.                 } catch(ClassNotFoundException ex) {  
  54.                     logger.log(Level.SEVERE, null, ex);  
  55.                 } finally {  
  56.                     try {  
  57.                         ois.close();  
  58.                     } catch(Exception ex) {}  
  59.                     try {  
  60.                         oos.close();  
  61.                     } catch(Exception ex) {}  
  62.                     try {  
  63.                         socket.close();  
  64.                     } catch(Exception ex) {}  
  65.                 }  
  66.             }  
  67.         }).start();  
  68.     }  

Client也和Server端类似,同样要不socket的XXXStream包装成GZIPXXXStream,然后再包装成ObjectXXXStream,如下:

  1. package com.googlecode.garbagecan.test.socket.sample4;  
  2.  
  3. import java.io.IOException;  
  4. import java.io.ObjectInputStream;  
  5. import java.io.ObjectOutputStream;  
  6. import java.net.InetSocketAddress;  
  7. import java.net.Socket;  
  8. import java.net.SocketAddress;  
  9. import java.util.logging.Level;  
  10. import java.util.logging.Logger;  
  11. import java.util.zip.GZIPInputStream;  
  12. import java.util.zip.GZIPOutputStream;  
  13.  
  14. public class MyClient {  
  15.       
  16.     private final static Logger logger = Logger.getLogger(MyClient.class.getName());  
  17.       
  18.     public static void main(String[] args) throws Exception {  
  19.         for (int i = 0; i < 10; i++) {  
  20.             Socket socket = null;  
  21.             GZIPOutputStream gzipos = null;  
  22.             ObjectOutputStream oos = null;  
  23.             GZIPInputStream gzipis = null;  
  24.             ObjectInputStream ois = null;  
  25.               
  26.             try {  
  27.                 socket = new Socket();  
  28.                 SocketAddress socketAddress = new InetSocketAddress("localhost"10000);   
  29.                 socket.connect(socketAddress, 10 * 1000);  
  30.                 socket.setSoTimeout(10 * 1000);  
  31.                   
  32.                 gzipos = new GZIPOutputStream(socket.getOutputStream());  
  33.                 oos = new ObjectOutputStream(gzipos);  
  34.                 User user = new User("user_" + i, "password_" + i);  
  35.                 oos.writeObject(user);  
  36.                 oos.flush();  
  37.                 gzipos.finish();  
  38.                   
  39.                 gzipis = new GZIPInputStream(socket.getInputStream());  
  40.                 ois = new ObjectInputStream(gzipis);  
  41.                 Object obj = ois.readObject();  
  42.                 if (obj != null) {  
  43.                     user = (User)obj;  
  44.                     System.out.println("user: " + user.getName() + "/" + user.getPassword());  
  45.                 }  
  46.             } catch(IOException ex) {  
  47.                 logger.log(Level.SEVERE, null, ex);  
  48.             }  
  49.             try {  
  50.                 oos.close();  
  51.             } catch (IOException e) {  
  52.             }  
  53.             try {  
  54.                 ois.close();  
  55.             } catch (IOException e) {  
  56.             }  
  57.             try {  
  58.                 socket.close();  
  59.             } catch (IOException e) {  
  60.             }  
  61.         }  
  62.     }  

***测试上面的代码,首先运行Server类,然后运行Client类,就可以分别在Server端和Client端控制台看到接收到的User对象实例了。

原文链接:http://blog.csdn.net/kongxx/article/details/7259834

【编辑推荐】

  1. Java Socket实战之三:传输对象
  2. Java Socket实战之二:多线程通信
  3. Java Socket实战之一:单线程通信
  4. Java多线程之消费者生产者模式
  5. 深入理解Java对象序列化
责任编辑:林师授 来源: kongxx的博客
相关推荐

2012-02-15 10:37:38

JavaJava Socket

2012-02-15 10:44:20

JavaJava Socket

2012-05-03 10:55:51

ApacheMINAJava

2012-05-03 11:35:56

ApacheCXFJava

2011-03-04 11:23:55

FileZilla

2010-03-19 16:38:29

Java Socket

2010-03-19 16:16:28

Java Socket

2010-03-19 16:28:51

Java Socket

2016-11-04 21:37:16

PythonSocket

2012-05-03 11:51:59

ApacheCXFJava

2009-10-21 13:17:38

Linux压缩打包方法

2012-03-19 10:35:51

ibmdw

2010-03-18 18:20:34

Java Socket

2012-05-07 14:15:41

ApacheCXFJava

2012-02-15 10:34:29

JavaJava Socket

2013-06-24 10:44:57

虚拟化网络设计

2015-03-26 11:25:10

对称加密加密压缩加密解密解压

2012-02-15 10:26:40

JavaJava Socket

2012-05-03 11:43:32

ApacheCXFRESTful

2018-01-12 17:03:29

HTTPgzip压缩
点赞
收藏

51CTO技术栈公众号