java控制台输出版多人聊天室

本文实例为大家分享了java控制台输出版多人聊天室的具体代码,供大家参考,具体内容如下

多人聊天室就要用到网络以及多线程以及输入输出流的知识

多人聊天室就是多个人同时聊天,一个发一条信息所有人都是可以接收得到.

接下来我们捋清楚一下思路

在这里面服务器充当了一个转发的作用,服务器要做的事情是,得到客户写进缓冲流里面的信息,再把得到的信息再写进其他客户端的缓冲流里面,得到其他用户的缓冲流我们可以通过集合把用户的全部Socket对象写进集合里面,客户端把客户想要发送的信息写进缓冲流里,等待客户端发来的消息,一边等由一边发送消息,这个是属于并发的一个操作,所以读与写可以单独开个线程来进行发送消息.

下面是客户端的代码

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;
import java.util.List;

public class Server {

    public static List<Socket> links = new ArrayList<>();  //用来存储客户端的socket对象

    public static void main(String[] args) throws IOException {                                      
        ServerSocket serverSocket = new ServerSocket(6666);
        while(true){
            Socket accept = serverSocket.accept();
            links.add(accept);             //只要有人连接就可以把他添加进socket对象集合里
            ServerThread serverThread = new ServerThread(accept);    //开启多线程,实现多人聊天的功能
            serverThread.start();
        }
}

//因为频繁的对输入输出流进行资源的关闭,所以写了个关闭资源的工具类
import java.io.Closeable;
import java.io.IOException;

public class CloseUtil {
    public static void close(Closeable... closeables){
        for (Closeable closeable : closeables) {
            if (closeable!=null) {
                try {
                    closeable.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

//多线程的代码如下
import java.io.*;
import java.net.Socket;
import java.util.List;

public class ServerThread extends Thread {
    private Socket socket;
    private boolean flag = true;
    public ServerThread(String name, Socket socket) {
        super(name);
        this.socket = socket;
    }

    @Override
    public void run() {
        while(flag){
            sendother(received());     //转发功能
        }
    }

    private void sendother(String str)  {
        List<Socket> links = Server.links;     //因为在写客户端的时候是socket的集合是 静态的属性,所以可以直接通过类型.属性直接获得
        for (Socket link : links) {
            if (link!=socket)
                 send(str,link);        //遍历整个对象转发给除当前对象的其他socket对象
        }

    }

    private void send(String str,Socket socket) {
        BufferedWriter bw = null;
        try {
            OutputStream outputStream = socket.getOutputStream();
            bw = new BufferedWriter(new OutputStreamWriter(outputStream));
            bw.write(str);
            bw.newLine();
            bw.flush();
        } catch (IOException e) {
            flag = false;
            CloseUtil.close(bw,socket);
        }

    }
    private String received(){
        BufferedReader br = null;
        try {
            InputStream inputStream = socket.getInputStream();
            br = new BufferedReader(new InputStreamReader(inputStream));
            return br.readLine();
        } catch (IOException e) {
            flag = false;
            CloseUtil.close(br,socket);
        }
        return null;
    }
}

下面是客户端的代码

import java.io.IOException;
import java.net.Socket;
import java.util.Scanner;

public class Client {
    public static void main(String[] args) throws IOException {

        Scanner input  = new Scanner(System.in);
        System.out.print("请输入您的名字:");
        String name = input.next();
        Socket socket = new Socket("127.0.0.1", 6666);  //127.0.0.1是指的是本机
        Send send = new Send(socket,name);          //收发分别开两个线程,可以收发并发执行
        Receive receive = new Receive("",socket);
        send.start();
        receive.start();
    }

}

//发线程
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.Socket;
import java.util.Scanner;

public class Send extends Thread {
    private Socket socket;
    private  boolean flag = true;
    public Send(Socket socket,String name) {
        super(name);
        this.socket = socket;
    }

    @Override
    public void run() {
        while(flag){
            send();   //一直循环保证客户可以一直发
        }
    }

    private void send() {
        Scanner input = new Scanner(System.in);
        BufferedWriter bw= null;
        try {
            OutputStream outputStream = socket.getOutputStream();
            bw = new BufferedWriter(new OutputStreamWriter(outputStream));
            bw.write(this.getName()+"说:"+input.next());      // 当前线程名+在客户端在控制台输出的一并发给服务端
            bw.newLine();
            bw.flush();
        } catch (IOException e) {
            flag = false;         //出现异常的时候关闭循环,防止陷入死循环
            CloseUtil.close(bw,socket);
        }

    }
}

//收线程
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.Socket;

public class Receive extends Thread {
    private Socket socket;
    private  boolean flag = true;
    public Receive(String name, Socket socket) {
        super(name);
        this.socket = socket;
    }

    @Override
    public void run() {
        while (flag){
            System.out.println(received());    //循环保证能一直接收服务器发来的消息
        }
    }
    public String received(){
        BufferedReader br =null;
        try {
            InputStream inputStream = socket.getInputStream();
            br = new BufferedReader(new InputStreamReader(inputStream));
            String line = br.readLine();
            return this.getName()+line;
        } catch (IOException e) {
            flag = false;
            CloseUtil.close(br,socket);
        }
        return "";
    }
}

以上就是简易版聊天室,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Java基于Tcp/ip连接的多人交互聊天室

    本文实例为大家分享了Java  Socket编程实现多人交互聊天室的具体代码,供大家参考,具体内容如下 本项目由三个.java文件(Client.java.Server.java.UI.java)和一个.jpg图片文件组成UI.java是负责界面的构成文件.本聊天室的界面极其简单.主要分为两个界面:第一个是启动时需要登陆的界面如下: 输入名字进去以后就可以直接聊天     这个聊天室相当于群聊,每一个登陆进去的人发的信息,其他人都会收到. 使用指南: 1.运行Server.java文件,保证服务

  • java编程实现多人聊天室功能

    本文实例为大家分享了java实现多人聊天室的具体代码,供大家参考,具体内容如下 程序源代码及运行截图: server.java //server.java package Socket; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.ServerSocket; impor

  • Java NIO Selector用法详解【含多人聊天室实例】

    本文实例讲述了Java NIO Selector用法.分享给大家供大家参考,具体如下: 一.Java NIO 的核心组件 Java NIO的核心组件包括:Channel(通道),Buffer(缓冲区),Selector(选择器),其中Channel和Buffer比较好理解 简单来说 NIO是面向通道和缓冲区的,意思就是:数据总是从通道中读到buffer缓冲区内,或者从buffer写入到通道中. 关于Channel 和 Buffer的详细讲解请看:Java NIO 教程 二.Java NIO Se

  • Java基于中介者模式实现多人聊天室功能示例

    本文实例讲述了Java基于中介者模式实现多人聊天室功能.分享给大家供大家参考,具体如下: 一 模式定义 中介者模式,用一个中介对象来封装一系列对象之间的交互,使各个对象中不需要显示地引用其他对象实例,从而降低各个对象之间的耦合度,并且可以独立地改变对象间的交互关系. 二 模式举例 1 模式分析 我们借用多人聊天室来说明这一模式 2 中介模式静态类图 3 代码示例 3.1中介者接口--IMediator package com.demo.mediator; import com.demo.coll

  • Java SE实现多人聊天室功能

    本文实例为大家分享了Java SE实现多人聊天室功能的具体代码,供大家参考,具体内容如下 实现功能: 1.实现用户注册上线,下线 2.实现群聊和私聊功能 3.实现统计当前在线人数 实现思路: 1.首先,要实现服务端与客户端之间的连接 这里是使用套接字建立TCP连接: (1)服务器端先实例化一个描述服务器端口号的ServerSocket对象 (2)客户端要创建Socket对象来连接指定的服务器端 (3)服务器端调用ServerSocket类的accept()方法来监听连接到服务器端的客户端信息 (

  • Java多线程实现多人聊天室功能

    本文为大家分享了Java多线程实现多人聊天室功能的具体代码,供大家参考,具体内容如下 1.实验目的: 编写一个 Java 应用程序,实现图形界面多人聊天室(多线程实现),要求聊天室窗口标题是 "欢迎使用 XXX 聊天室应用",其中 XXX 是自己的班级姓名学号,如"软件 171 张三 1234". 2.实验代码: 服务端程序代码: ServerChar.java package works; import java.io.DataInputStream; impor

  • Java实现多人聊天室的原理与源码

    多人聊天室原理图 源码 工具类: 该类用于关闭各种流. public class CloseUtil { public static void CloseAll(Closeable... closeable){ for(Closeable c:closeable){ if (c != null) { try { c.close(); } catch (IOException e) { e.printStackTrace(); } } } } } 服务器: 服务器端创建一个serverSocket

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

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

  • 基于java编写局域网多人聊天室

    由于需要制作网络计算机网络课程设计,并且不想搞网络布线或者局域网路由器配置等等这种完全搞不懂的东西,最后决定使用socket基于java编写一个局域网聊天室: 关于socket以及网络编程的相关知识详见我另一篇文章:Java基于socket编程 程序基于C/S结构,即客户端服务器模式. 服务器: 默认ip为本机ip 需要双方确定一个端口号 可设置最大连接人数 可启动与关闭 界面显示在线用户人以及姓名(本机不在此显示) 客户端: 需要手动设置服务器ip地址(局域网) 手动设置端口号 输入姓名 可连

  • java使用MulticastSocket实现基于广播的多人聊天室

    使用MulticastSocket实现多点广播: (1)DatagramSocket只允许数据报发给指定的目标地址,而MulticastSocket可以将数据报以广播的方式发送到多个客户端. (2)IP协议为多点广播提供了这批特殊的IP地址,这些IP地址的范围是:224.0.0.0至239.255.255.255.. (3)MulticastSocket类时实现多点广播的关键,当MulticastSocket把一个DaragramPocket发送到多点广播的IP地址时,该数据报将会自动广播到加入

随机推荐