Java Socket实战之三:传输对象

开发 后端
这一篇说一下怎样使用Java Socket来传输对象。首先需要一个普通的对象类,由于需要序列化这个对象以便在网络上传输,所以实现java.io.Serializable接口就是必不可少的了。

前面两篇文章介绍了怎样建立Java Socket通信,这一篇说一下怎样使用Java Socket来传输对象。

首先需要一个普通的对象类,由于需要序列化这个对象以便在网络上传输,所以实现java.io.Serializable接口就是必不可少的了,如下:

  1. package com.googlecode.garbagecan.test.socket.sample3;  
  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.     }  

对于Server端的代码,代码中分别使用了ObjectInputStream和ObjectOutputStream来接收和发送socket中的InputStream和OutputStream,然后转换成Java对象,如下:

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

Client也和Server端类似,同样使用ObjectOutputStream和ObjectInputStream来处理,如下:

  1. package com.googlecode.garbagecan.test.socket.sample3;  
  2.  
  3. import java.io.BufferedInputStream;  
  4. import java.io.IOException;  
  5. import java.io.ObjectInputStream;  
  6. import java.io.ObjectOutputStream;  
  7. import java.net.Socket;  
  8. import java.util.logging.Level;  
  9. import java.util.logging.Logger;  
  10.  
  11. public class MyClient {  
  12.       
  13.     private final static Logger logger = Logger.getLogger(MyClient.class.getName());  
  14.       
  15.     public static void main(String[] args) throws Exception {  
  16.         for (int i = 0; i < 100; i++) {  
  17.             Socket socket = null;  
  18.             ObjectOutputStream os = null;  
  19.             ObjectInputStream is = null;  
  20.               
  21.             try {  
  22.                 socket = new Socket("localhost"10000);  
  23.       
  24.                 os = new ObjectOutputStream(socket.getOutputStream());  
  25.                 User user = new User("user_" + i, "password_" + i);  
  26.                 os.writeObject(user);  
  27.                 os.flush();  
  28.                   
  29.                 is = new ObjectInputStream(new BufferedInputStream(socket.getInputStream()));  
  30.                 Object obj = is.readObject();  
  31.                 if (obj != null) {  
  32.                     user = (User)obj;  
  33.                     System.out.println("user: " + user.getName() + "/" + user.getPassword());  
  34.                 }  
  35.             } catch(IOException ex) {  
  36.                 logger.log(Level.SEVERE, null, ex);  
  37.             } finally {  
  38.                 try {  
  39.                     is.close();  
  40.                 } catch(Exception ex) {}  
  41.                 try {  
  42.                     os.close();  
  43.                 } catch(Exception ex) {}  
  44.                 try {  
  45.                     socket.close();  
  46.                 } catch(Exception ex) {}  
  47.             }  
  48.         }  
  49.     }  

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

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

【编辑推荐】

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

2012-05-03 11:35:56

ApacheCXFJava

2012-02-15 10:40:37

JavaJava Socket

2012-02-15 10:44:20

JavaJava Socket

2012-05-03 10:55:51

ApacheMINAJava

2013-05-28 09:33:47

虚拟化虚拟化存储

2013-06-08 11:10:36

虚拟化虚拟化存储

2013-12-11 10:40:31

虚拟化实战Cluster

2019-09-18 18:32:29

前端javascriptoop

2016-11-04 21:37:16

PythonSocket

2010-03-19 16:16:28

Java Socket

2010-03-19 16:28:51

Java Socket

2012-03-15 17:18:33

JavaHashMap

2010-03-19 16:38:29

Java Socket

2010-03-18 18:20:34

Java Socket

2012-03-19 10:35:51

ibmdw

2012-02-15 10:34:29

JavaJava Socket

2015-10-30 15:30:54

LevelDBSSTableSybase

2009-02-04 09:45:05

Java SocketSocket APIJava编程

2012-02-15 10:26:40

JavaJava Socket

2020-11-13 08:30:57

Socket
点赞
收藏

51CTO技术栈公众号