java Socket实现网页版在线聊天

本文为大家分享了一个满足在线网页交流需求的实例,由于java Socket实现的网页版在线聊天功能,供大家参考,具体内容如下

实现步骤:

1、使用awt组件和socket实现简单的单客户端向服务端持续发送消息;
2、结合线程,实现多客户端连接服务端发送消息;
3、实现服务端转发客户端消息至所有客户端,同时在客户端显示;
4、把awt组件生成的窗口界面改成前端jsp或者html展示的界面,java socket实现的客户端改为前端技术实现。

这里首先实现第一步的简单功能,难点在于:
1、没有用过awt组件,没有用过java相关的监听事件;
2、长时间没有使用socket进行客户端和服务端的交互,并且没有真正进行过cs结构的开发。

实现功能的代码

在线聊天客户端:

1、生成图形窗口界面轮廓
2、为轮廓添加关闭事件
3、在轮廓中加入输入区域和内容展示区域
4、为输入区域添加回车事件
5、建立服务端连接并发送数据

package chat.chat; 

import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.TextArea;
import java.awt.TextField;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException; 

/**
 * 在线聊天客户端 1、生成图形窗口界面轮廓 2、为轮廓添加关闭事件 3、在轮廓中加入输入区域和内容展示区域 4、为输入区域添加回车事件
 * 5、建立服务端连接并发送数据
 *
 * @author tuzongxun123
 *
 */
public class ChatClient extends Frame {
  // 用户输入区域
  private TextField tfTxt = new TextField();
  // 内容展示区域
  private TextArea tarea = new TextArea();
  private Socket socket = null;
  // 数据输出流
  private DataOutputStream dataOutputStream = null; 

  public static void main(String[] args) {
    new ChatClient().launcFrame();
  } 

  /**
   * 建立一个简单的图形化窗口
   *
   * @author:tuzongxun
   * @Title: launcFrame
   * @param
   * @return void
   * @date May 18, 2016 9:57:00 AM
   * @throws
   */
  public void launcFrame() {
    setLocation(300, 200);
    this.setSize(200, 400);
    add(tfTxt, BorderLayout.SOUTH);
    add(tarea, BorderLayout.NORTH);
    pack();
    // 监听图形界面窗口的关闭事件
    this.addWindowListener(new WindowAdapter() { 

      @Override
      public void windowClosing(WindowEvent e) {
        System.exit(0);
        disConnect();
      }
    });
    tfTxt.addActionListener(new TFLister());
    setVisible(true);
    connect();
  } 

  /**
   * 连接服务器
   *
   * @author:tuzongxun
   * @Title: connect
   * @param
   * @return void
   * @date May 18, 2016 9:56:49 AM
   * @throws
   */
  public void connect() {
    try {
      // 新建服务端连接
      socket = new Socket("127.0.0.1", 8888);
      // 获取客户端输出流
      dataOutputStream = new DataOutputStream(socket.getOutputStream());
      System.out.println("连上服务端");
    } catch (UnknownHostException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  } 

  /**
   * 关闭客户端资源
   *
   * @author:tuzongxun
   * @Title: disConnect
   * @param
   * @return void
   * @date May 18, 2016 9:57:46 AM
   * @throws
   */
  public void disConnect() {
    try {
      dataOutputStream.close();
      socket.close();
    } catch (IOException e) {
      e.printStackTrace();
    }
  } 

  /**
   * 向服务端发送消息
   *
   * @author:tuzongxun
   * @Title: sendMessage
   * @param @param text
   * @return void
   * @date May 18, 2016 9:57:56 AM
   * @throws
   */
  private void sendMessage(String text) {
    try {
      dataOutputStream.writeUTF(text);
      dataOutputStream.flush();
    } catch (IOException e1) {
      e1.printStackTrace();
    }
  } 

  /**
   * 图形窗口输入区域监听回车事件
   *
   * @author tuzongxun123
   *
   */
  private class TFLister implements ActionListener { 

    @Override
    public void actionPerformed(ActionEvent e) {
      String text = tfTxt.getText().trim();
      tarea.setText(text);
      tfTxt.setText("");
      // 回车后发送数据到服务器
      sendMessage(text);
    }
  }
}

服务端:

package chat.chat; 

import java.io.DataInputStream;
import java.io.EOFException;
import java.io.IOException;
import java.net.BindException;
import java.net.ServerSocket;
import java.net.Socket; 

/**
 * java使用socket和awt组件简单实现在线聊天功能服务端 可以实现一个客户端连接后不断向服务端发送消息
 * 但不支持多个客户端同时连接,原因在于代码中获得客户端连接后会一直循环监听客户端输入,造成阻塞
 * 以至于服务端无法二次监听另外的客户端,如要实现,需要使用异步或者多线程
 *
 * @author tuzongxun123
 *
 */
public class ChatServer { 

  public static void main(String[] args) {
    // 是否成功启动服务端
    boolean isStart = false;
    // 服务端socket
    ServerSocket ss = null;
    // 客户端socket
    Socket socket = null;
    // 服务端读取客户端数据输入流
    DataInputStream dataInputStream = null;
    try {
      // 启动服务器
      ss = new ServerSocket(8888);
    } catch (BindException e) {
      System.out.println("端口已在使用中");
      // 关闭程序
      System.exit(0);
    } catch (Exception e) {
      e.printStackTrace();
    } 

    try {
      isStart = true;
      while (isStart) {
        boolean isConnect = false;
        // 启动监听
        socket = ss.accept();
        System.out.println("one client connect");
        isConnect = true;
        while (isConnect) {
          // 获取客户端输入流
          dataInputStream = new DataInputStream(
              socket.getInputStream());
          // 读取客户端传递的数据
          String message = dataInputStream.readUTF();
          System.out.println("客户端说:" + message);
        } 

      }
    } catch (EOFException e) {
      System.out.println("client closed!");
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      // 关闭相关资源
      try {
        dataInputStream.close();
        socket.close();
      } catch (IOException e) {
        e.printStackTrace();
      }
    }
  }
}

继续,在单客户端连接的基础上,这里第二步需要实现多客户端的连接,也就需要使用到线程。每当有一个新的客户端连接上来,服务端便需要新启动一个线程进行处理,从而解决之前的循环读取中造成阻塞的问题。

写线程通常有两种方法,集成Thread或者实现runnable接口,原则上是能实现runnable的情况下就不继承,因为实现接口的方式更加灵活。

客户端代码相较之前没有变化,变得是服务端,因此这里便只贴出服务端代码:

java使用socket和awt组件以及多线程简单实现在线聊天功能服务端 :

实现多个客户端连接后不断向服务端发送消息, 相对于第一个版本,重点在于使用了多线程。服务端还未实现转发功能,客户端图形窗口中只能看到自己输入的信息,不能看到其他客户端发送的消息。

package chat.chat; 

import java.io.DataInputStream;
import java.io.EOFException;
import java.io.IOException;
import java.net.BindException;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketException; 

/**
 * *
 * @author tuzongxun123
 *
 */
public class ChatServer { 

  public static void main(String[] args) {
    new ChatServer().start();
  } 

  // 是否成功启动服务端
  private boolean isStart = false;
  // 服务端socket
  private ServerSocket ss = null;
  // 客户端socket
  private Socket socket = null; 

  public void start() {
    try {
      // 启动服务器
      ss = new ServerSocket(8888);
    } catch (BindException e) {
      System.out.println("端口已在使用中");
      // 关闭程序
      System.exit(0);
    } catch (Exception e) {
      e.printStackTrace();
    } 

    try {
      isStart = true;
      while (isStart) {
        // 启动监听
        socket = ss.accept();
        System.out.println("one client connect");
        // 启动客户端线程
        Client client = new Client(socket);
        new Thread(client).start();
      }
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      // 关闭服务
      try {
        ss.close();
      } catch (IOException e) {
        e.printStackTrace();
      }
    } 

  } 

  /**
   * 客户端线程
   *
   * @author tuzongxun123
   *
   */
  class Client implements Runnable {
    // 客户端socket
    private Socket socket = null;
    // 客户端输入流
    private DataInputStream dataInputStream = null;
    private boolean isConnect = false; 

    public Client(Socket socket) {
      this.socket = socket;
      try {
        isConnect = true;
        // 获取客户端输入流
        dataInputStream = new DataInputStream(socket.getInputStream());
      } catch (IOException e) {
        e.printStackTrace();
      }
    } 

    @Override
    public void run() {
      isConnect = true;
      try {
        while (isConnect) {
          // 读取客户端传递的数据
          String message = dataInputStream.readUTF();
          System.out.println("客户端说:" + message);
        }
      } catch (EOFException e) {
        System.out.println("client closed!");
      } catch (SocketException e) {
        System.out.println("Client is Closed!!!!");
      } catch (Exception e) {
        e.printStackTrace();
      } finally {
        // 关闭相关资源
        try {
          dataInputStream.close();
          socket.close();
        } catch (IOException e) {
          e.printStackTrace();
        }
      }
    } 

  } 

}

上面主要介绍了利用线程使服务端实现了能够接收多客户端请求的功能,这里便需要客户端接收多客户端消息的同时还能把消息转发到每个连接的客户端,并且客户端要能在内容显示区域显示出来,从而实现简单的在线群聊。

在实现客户端转发,无非就是增加输出流;而之前客户端都只发不收,这里也需要更改客户端达到循环接收服务端消息的目的,因此也需要实现多线程。

在实现这个功能的时候,偶然想起随机生成验证码的功能,于是也灵机一动随机给每个客户端生成一个名字,从而在输出的时候看起来更加像是群聊,不仅有消息输出,还能看到是谁。

实现这些功能之后,基本上就可以几个人同时在线群聊了,因为代码中有main方法,因此可以把服务端和客户端都打成可执行jar包,可参考我的另一篇博文:使用eclipse创建java程序可执行jar包

之后在桌面双击相应的jar文件启动服务端和客户端即可,不需要再依赖eclipse运行。

修改后的客户端代码如下:

package chat.chat; 

import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.TextArea;
import java.awt.TextField;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Random; 

/**
 * 在线聊天客户端 步骤: 

 *1、生成图形窗口界面轮廓 

 *2、为轮廓添加关闭事件 

 *3、在轮廓中加入输入区域和内容展示区域 

 *4、为输入区域添加回车事件
 * 5、建立服务端连接并发送数据
 *
 * @author tuzongxun123
 *
 */
public class ChatClient extends Frame {
  /**
   *
   */
  private static final long serialVersionUID = 1L;
  // 用户输入区域
  private TextField tfTxt = new TextField();
  // 内容展示区域
  private TextArea tarea = new TextArea();
  private Socket socket = null;
  // 数据输出流
  private DataOutputStream dataOutputStream = null;
  // 数据输入流
  private DataInputStream dataInputStream = null;
  private boolean isConnect = false;
  Thread tReceive = new Thread(new ReceiveThread());
  String name = ""; 

  public static void main(String[] args) {
    ChatClient chatClient = new ChatClient();
    chatClient.createName();
    chatClient.launcFrame(); 

  } 

  /**
   * 建立一个简单的图形化窗口
   *
   * @author:tuzongxun
   * @Title: launcFrame
   * @param
   * @return void
   * @date May 18, 2016 9:57:00 AM
   * @throws
   */
  public void launcFrame() {
    setLocation(300, 200);
    this.setSize(200, 400);
    add(tfTxt, BorderLayout.SOUTH);
    add(tarea, BorderLayout.NORTH);
    // 根据窗口里面的布局及组件的preferedSize来确定frame的最佳大小
    pack();
    // 监听图形界面窗口的关闭事件
    this.addWindowListener(new WindowAdapter() { 

      @Override
      public void windowClosing(WindowEvent e) {
        System.exit(0);
        disConnect();
      }
    });
    tfTxt.addActionListener(new TFLister());
    // 设置窗口可见
    setVisible(true);
    connect();
    // 启动接受消息的线程
    tReceive.start();
  } 

  /**
   * 连接服务器
   *
   * @author:tuzongxun
   * @Title: connect
   * @param
   * @return void
   * @date May 18, 2016 9:56:49 AM
   * @throws
   */
  public void connect() {
    try {
      // 新建服务端连接
      socket = new Socket("127.0.0.1", 8888);
      // 获取客户端输出流
      dataOutputStream = new DataOutputStream(socket.getOutputStream());
      dataInputStream = new DataInputStream(socket.getInputStream());
      System.out.println("连上服务端");
      isConnect = true;
    } catch (UnknownHostException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  } 

  // 生成随机的客户端名字
  public void createName() {
    String[] str1 = { "a", "b", "c", "d", "e", "f", "g", "h", "i", "j",
        "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v",
        "w", "x", "y", "z", "1", "2", "3", "4", "5", "6", "7", "8",
        "9", "0", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J",
        "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
        "W", "X", "Y", "Z" };
    Random ran = new Random(); 

    for (int i = 0; i < 6; i++) {
      // long num = Math.round(Math.random() * (str1.length - 0) + 0);
      // int n = (int) num;
      int n = ran.nextInt(str1.length);
      if (n < str1.length) {
        String str = str1[n];
        name = name + str;
        System.out.println(name);
      } else {
        i--;
        continue;
      } 

    }
    this.setTitle(name);
  } 

  /**
   * 关闭客户端资源
   *
   * @author:tuzongxun
   * @Title: disConnect
   * @param
   * @return void
   * @date May 18, 2016 9:57:46 AM
   * @throws
   */
  public void disConnect() {
    try {
      isConnect = false;
      // 停止线程
      tReceive.join();
    } catch (InterruptedException e) {
      e.printStackTrace();
    } finally {
      try {
        if (dataOutputStream != null) {
          dataOutputStream.close();
        }
        if (socket != null) {
          socket.close();
          socket = null;
        } 

      } catch (IOException e) {
        e.printStackTrace();
      }
    }
  } 

  /**
   * 向服务端发送消息
   *
   * @author:tuzongxun
   * @Title: sendMessage
   * @param @param text
   * @return void
   * @date May 18, 2016 9:57:56 AM
   * @throws
   */
  private void sendMessage(String text) {
    try {
      dataOutputStream.writeUTF(name + ":" + text);
      dataOutputStream.flush();
    } catch (IOException e1) {
      e1.printStackTrace();
    }
  } 

  /**
   * 图形窗口输入区域监听回车事件
   *
   * @author tuzongxun123
   *
   */
  private class TFLister implements ActionListener { 

    @Override
    public void actionPerformed(ActionEvent e) {
      String text = tfTxt.getText().trim();
      // 清空输入区域信息
      tfTxt.setText("");
      // 回车后发送数据到服务器
      sendMessage(text);
    } 

  } 

  private class ReceiveThread implements Runnable { 

    @Override
    public void run() {
      try {
        while (isConnect) {
          String message = dataInputStream.readUTF();
          System.out.println(message);
          String txt = tarea.getText();
          if (txt != null && !"".equals(txt.trim())) {
            message = tarea.getText() + "\n" + message;
          }
          tarea.setText(message);
        }
      } catch (IOException e) {
        e.printStackTrace();
      }
    } 

  }
}

修改后的服务端代码如下:

package chat.chat; 

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.EOFException;
import java.io.IOException;
import java.net.BindException;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketException;
import java.util.ArrayList;
import java.util.List; 

/**
 * java使用socket和awt组件以及多线程简单实现在线聊天功能服务端 :
 * 实现服务端把接收到的客户端信息转发到所有连接的客户端,并且让客户端读取到这些信息并显示在内容显示区域中。
 *
 * @author tuzongxun123
 *
 */
public class ChatServer { 

  public static void main(String[] args) {
    new ChatServer().start();
  } 

  // 是否成功启动服务端
  private boolean isStart = false;
  // 服务端socket
  private ServerSocket ss = null;
  // 客户端socket
  private Socket socket = null;
  // 保存客户端集合
  List<Client> clients = new ArrayList<Client>(); 

  public void start() {
    try {
      // 启动服务器
      ss = new ServerSocket(8888);
    } catch (BindException e) {
      System.out.println("端口已在使用中");
      // 关闭程序
      System.exit(0);
    } catch (Exception e) {
      e.printStackTrace();
    } 

    try {
      isStart = true;
      while (isStart) {
        // 启动监听
        socket = ss.accept();
        System.out.println("one client connect");
        // 启动客户端线程
        Client client = new Client(socket); 

        new Thread(client).start();
        clients.add(client);
      }
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      // 关闭服务
      try {
        ss.close();
      } catch (IOException e) {
        e.printStackTrace();
      }
    } 

  } 

  /**
   * 客户端线程
   *
   * @author tuzongxun123
   *
   */
  private class Client implements Runnable {
    // 客户端socket
    private Socket socket = null;
    // 客户端输入流
    private DataInputStream dataInputStream = null;
    // 客户端输出流
    private DataOutputStream dataOutputStream = null;
    private boolean isConnect = false; 

    public Client(Socket socket) {
      this.socket = socket;
      try {
        isConnect = true;
        // 获取客户端输入流
        dataInputStream = new DataInputStream(socket.getInputStream());
        // 获取客户端输出流
        dataOutputStream = new DataOutputStream(
            socket.getOutputStream());
      } catch (IOException e) {
        e.printStackTrace();
      }
    } 

    /**
     * 向客户端群发(转发)数据
     *
     * @author:tuzongxun
     * @Title: sendMessageToClients
     * @param @param message
     * @return void
     * @date May 18, 2016 11:28:10 AM
     * @throws
     */
    public void sendMessageToClients(String message) {
      try {
        dataOutputStream.writeUTF(message);
      } catch (SocketException e) { 

      } catch (IOException e) {
        e.printStackTrace();
      }
    } 

    @Override
    public void run() {
      isConnect = true;
      Client c = null;
      try {
        while (isConnect) {
          // 读取客户端传递的数据
          String message = dataInputStream.readUTF();
          System.out.println("客户端说:" + message);
          for (int i = 0; i < clients.size(); i++) {
            c = clients.get(i); 

            c.sendMessageToClients(message);
          } 

        }
      } catch (EOFException e) {
        System.out.println("client closed!");
      } catch (SocketException e) {
        if (c != null) {
          clients.remove(c);
        }
        System.out.println("Client is Closed!!!!");
      } catch (Exception e) {
        e.printStackTrace();
      } finally {
        // 关闭相关资源
        try {
          if (dataInputStream != null) {
            dataInputStream.close();
          }
          if (socket != null) {
            socket.close();
            socket = null;
          }
        } catch (IOException e) {
          e.printStackTrace();
        }
      }
    }
  } 

}

就先为大家介绍到这里,之后如果有新的内容再为大家进行更新。

关于网页在线聊天功能的实现大,大家还可以参考一下几篇文章进行学习:

java实现一个简单TCPSocket聊天室功能分享

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家可以继续关注我们的更多精彩内容。

(0)

相关推荐

  • 使用Java和WebSocket实现网页聊天室实例代码

    在没介绍正文之前,先给大家介绍下websocket的背景和原理: 背景 在浏览器中通过http仅能实现单向的通信,comet可以一定程度上模拟双向通信,但效率较低,并需要服务器有较好的支持; flash中的socket和xmlsocket可以实现真正的双向通信,通过 flex ajax bridge,可以在javascript中使用这两项功能. 可以预见,如果websocket一旦在浏览器中得到实现,将会替代上面两项技术,得到广泛的使用.面对这种状况,HTML5定义了WebSocket协议,能更

  • 基于Java Socket实现一个简易在线聊天功能(一)

    最近做了一个项目,其中有一个在线网页交流的需求,好久没写代码了,手都生疏了,于是先写demo练练手,分享到我们平台,以此做个记录,方便自己和大家使用. 先给大家说下实现步骤分这样几大步: 1.使用awt组件和socket实现简单的单客户端向服务端持续发送消息: 2.结合线程,实现多客户端连接服务端发送消息: 3.实现服务端转发客户端消息至所有客户端,同时在客户端显示: 4.把awt组件生成的窗口界面改成前端jsp或者html展示的界面,java socket实现的客户端改为前端技术实现. 这里首

  • RxJava的消息发送和线程切换实现原理

    RxJava是一个在Java虚拟机上的响应式扩展,通过使用可观察的序列将异步和基于事件的程序组合起来的一个库. 它扩展了观察者模式来支持数据/事件序列,并且添加了操作符,这些操作符允许你声明性地组合序列,同时抽象出要关注的问题:比如低级线程.同步.线程安全和并发数据结构等. RxJava相信大家都非常了解吧,今天分享一下RxJava的消息发送和线程源码的分析.最后并分享一个相关demo,让大家更加熟悉我们天天都在用的框架. 消息订阅发送 首先让我们看看消息订阅发送最基本的代码组成: Observ

  • Java 基于UDP协议实现消息发送

    发短信:不用连接,但需要知道对方的地址,客户端.服务端没有明确的界限,可以说没有客户端.服务端一说. 发送端 package lesson03; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.InetAddress; /** * 发送端 */ public class UdpClientDemo1 { public static void main(String[] args) th

  • Java基于socket实现简易聊天室实例

    本文实例讲述了Java基于socket实现简易聊天室的方法.分享给大家供大家参考.具体实现方法如下: chatroomdemo.java package com.socket.demo; import java.io.IOException; import java.net.DatagramSocket; public class ChatRoomDemo { /** * @param args * @throws IOException */ public static void main(S

  • java聊天室的实现代码

    本文实例为大家分享了java实现聊天室的具体代码,供大家参考,具体内容如下 聊天室界面: 源码: public class ClientFrame extends Frame { private TextField textFieldContent = new TextField(); private TextArea textAreaContent = new TextArea(); private Socket socket = null; private OutputStream out

  • Java网络编程UDP实现消息发送及聊天

    TCP可以实现聊天,UDP也可以实现消息发送及聊天.不同的是,TCP需要有服务端和客户端的连接,但UDP不需要,只需要有发送方和接收方即可. 一.实现消息发送 发送方: package com.kuang.lesson03; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.InetAddress; import java.net.SocketException; //不需要连接服务器

  • java实现自动回复聊天机器人

    本文实例为大家分享了java实现自动回复聊天机器人的具体代码,供大家参考,具体内容如下 聊天机器人 调用网上现有的接口,然后解析数据 以上是演示图片 源码下载地址 基本工作流程就是,调用API,解析返回的数据 HttpUtil类,调用API,获取返回的数据 package com; import com.sun.org.apache.bcel.internal.generic.INSTANCEOF; import java.io.BufferedReader; import java.io.In

  • java实现一个简单TCPSocket聊天室功能分享

    本文实例为大家分享了java实现TCPSocket聊天室功能的相关代码,供大家参考,具体内容如下 1.TCPserver.java import java.net.*; import java.io.*; import java.util.*; import java.util.concurrent.*; public class TCPserver{ private static final int SERVERPORT = 8888; private ServerSocket MyServe

  • java socket实现聊天室 java实现多人聊天功能

    用java socket做一个聊天室,实现多人聊天的功能.看了极客学院的视频后跟着敲的.(1DAY) 服务端: 1. 先写服务端的类MyServerSocket,里面放一个监听线程,一启动就好 2. 实现服务端监听类ServerListener.java,用accept来监听,一旦有客户端连上,生成新的socket,就新建个线程实例ChatSocket.启动线程后就把线程交给ChatManager管理 3. 在ChatSocket中实现从客户端读取内容,把读取到的内容发给集合内所有的客户端 4.

  • java中UDP简单聊天程序实例代码

    学过计算机网络通信的都知道,计算机之间传送数据由两种,即TCP通信和UDP通信.TCP是可靠的面向连接的通信协议,二UDP是不可靠的面向无连接的通信协议. java中有基于TCP的网络套接字通信,也有基于UDP的用户数据报通信,UDP的信息传输速度快,但不可靠! 基于UDP通信的基本模式: (1)将数据打包,称为数据包(好比将信件装入信封一样),然后将数据包发往目的地. (2)接受别人发来的数据包(好比接收信封一样),然后查看数据包中的内容. 客户机 复制代码 代码如下: package com

随机推荐