java实现实时通信聊天程序

 更新时间:2022年06月10日 15:58:25   作者:惘者  
这篇文章主要为大家详细介绍了java实现实时通信聊天程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

利用TCP传输数据,编写客户端和服务器的程序,实现两个程序间的实时通信。

在每个程序中实现了实时的发送与接收数据的功能。

客户端的io界面

服务器端的io界面

io演示

程序以两端分别输入close字符串作为结束标识。在一端输入close时,终止发送、一端接收到close时,终止接收。所演示的客户端来自个人电脑IDEA调试运行。服务器端来自阿里云服务器centos系统下的jdk环境。该程序需要用到java的 I/O 流、多线程、网络编程的相关知识。

一、客户端

由于发送和接收数据是并行的,为了使得时刻都能同时进行接受与发送的功能,使用多线程,将接收和发送分别封装为两个Runnable实现类。获取io信息。

ClientDemo类的源码:

public class ClientDemo {
    public static Socket s;
    public static void main(String[] args) throws IOException, InterruptedException {
        s = new Socket("localhost", 10000);        //此处的参数一填写服务器端ip地址
        System.out.println("连接成功");
        Thread send = new Thread(new COUT());
        Thread receive = new Thread(new CIN());
        send.start();
        receive.start();
        send.join();        //发送和接收执行完毕时,关闭套接字
        receive.join();        //因此待这两个线程结束时才回到主线程执行。
        s.close();
    }
}

创建全局变量套接字s,在主进程中给s进行初始化,然后启动发送和接收功能的两个线程。

Socket构造时传递的两个参数,其一填写服务器地址。或者填写localhost即127.0.0.1回送地址,本机即可运行服务器端和客户端进行本地数据传输。

其二是端口数,需要保持客户端和服务器端的套接字绑定的端口数一致。尽可能选用数量大的端口以免被占用,如果运行时报错端口已占用可以尝试更改端口数,范围在65536内。

客户端发送和接收类的源码:

class CIN implements Runnable{
    @Override
    public void run() {        //接收模块
        try {
            InputStream is = ClientDemo.s.getInputStream();//通过全局套接字s获取连接后的流
            in(is);
        }
        catch (IOException o) {
            o.printStackTrace();
        }
    }
    public static void in(InputStream is) throws IOException{
        while(true){
            byte[] bytes = new byte[1024];
            int len = is.read(bytes);
            String line = new String(bytes,0,len);
 
            System.out.println("对方:   "+line);
            if(line.equals("close"))
                break;
        }
    }
}
 
class COUT implements Runnable{
    @Override
    public void run() {        //发送模块
        try {
            OutputStream os = ClientDemo.s.getOutputStream();//套接字获取流
            out(os);
        }
        catch (IOException o){
            o.printStackTrace();
        }
    }
    public static void out(OutputStream os) throws IOException{
        Scanner sc = new Scanner(System.in);
        while(true) {
            String line = sc.nextLine();
            os.write(line.getBytes());
            if(line.equals("close"))
                break;
        }
        sc.close();
    }
}

由于IO流都由socket创建,因此程序结束时需要关闭s即可。

二、服务器

ServerDemo类的源码:

public class ServerDemo {
    public static ServerSocket ss;
    public static Socket s;
 
    public static void main(String[] args) throws IOException, InterruptedException {
        ss = new ServerSocket(10000);        //监听端口10000,对应客户端套接字绑定的端口
        s = ss.accept();        //提取监听套接字中的一个连接
        System.out.println("连接成功");
        Thread send = new Thread(new SOUT());
        Thread receive = new Thread(new SIN());
        send.start();
        receive.start();
        send.join();
        receive.join();
        ss.close();
    }
}

创建服务器套接字对象并监听,并接收连接请求。

此处的代码与客户端大同小异,完成连接后的代码基本一致。

服务器端发送和接收类的源码:

class SIN implements Runnable{
    @Override
    public void run() {
        try {
            InputStream is = ServerDemo.s.getInputStream();
            in(is);
        }
        catch (IOException o) {
            o.printStackTrace();
        }
    }
    public static void in(InputStream is) throws IOException{
        while(true){
            byte[] bytes = new byte[1024];
            int len = is.read(bytes);
            String line = new String(bytes,0,len);
            System.out.println("对方:   "+line);
            if(line.equals("close"))
                break;
        }
    }
}
class SOUT implements Runnable{
    @Override
    public void run() {
        try {
            OutputStream os = ServerDemo.s.getOutputStream();
            out(os);
        }
        catch (IOException o){
            o.printStackTrace();
        }
    }
    public static void out(OutputStream os) throws IOException{
        Scanner sc = new Scanner(System.in);
        while(true) {
            String line = sc.nextLine();
            os.write(line.getBytes());
            if(line.equals("close"))
                break;
        }
        sc.close();
    }
}

两者代码不同的地方在于由于套接字不同,返回的流实例不同。基本逻辑相同。

本地可同时运行客户端和服务器端,客户端套接字绑定本地ip地址,“localhost或127.0.0.1。

先开启服务器端进行监听,然后打开客户端向服务器端发起连接请求。连接成功后即可实时进行聊天。在程序中以一行为信息单元,键入若干字符后换行发送。另一端即可收到信息。

在一端键入“close”发送即可关闭当前程序的发送线程和接收程序的接收线程。待两个程序的所有发送和接收都结束时,关闭程序。

实测记录:将服务器端程序发送至云服务器通过jdk运行,并开启程序监听,将客户端的套接字指向服务器端的地址和监听端口。之后建立连接,可自由在两端传输信息。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • IDEA 自动生成 JPA 实体类的图文教程

    IDEA 自动生成 JPA 实体类的图文教程

    这篇文章主要介绍了IDEA 自动生成 JPA 实体类的图文教程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 浅谈Java中各种修饰符与访问修饰符的说明

    浅谈Java中各种修饰符与访问修饰符的说明

    下面小编就为大家带来一篇浅谈Java中各种修饰符与访问修饰符的说明。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • 详解重试框架Spring retry实践

    详解重试框架Spring retry实践

    spring retry是从spring batch独立出来的一个能功能,主要实现了重试和熔断。这篇文章主要介绍了详解重试框架Spring retry实践,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05
  • javaweb文件打包批量下载代码

    javaweb文件打包批量下载代码

    这篇文章主要为大家详细介绍了javaweb文件打包批量下载代码,批量下载未批改作业,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • java自定义任务类定时执行任务示例 callable和future接口使用方法

    java自定义任务类定时执行任务示例 callable和future接口使用方法

    Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务
    2014-01-01
  • Java生产者消费者模式实例分析

    Java生产者消费者模式实例分析

    这篇文章主要介绍了Java生产者消费者模式,结合实例形式分析了java生产者消费者模式的相关组成、原理及实现方法,需要的朋友可以参考下
    2019-03-03
  • Java数据结构与算法实现递归与回溯

    Java数据结构与算法实现递归与回溯

    本文主要介绍了Java数据结构与算法实现递归与回溯,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • JDK1.7的ConcurrentHashMap源码解析

    JDK1.7的ConcurrentHashMap源码解析

    这篇文章主要介绍了JDK1.7的ConcurrentHashMap源码解析,HashMap是非线程安全的,而HashTable是线程安全的,但是HashTable实现同步的方法比较暴力,即在所有的方法体上添加synchronized关键字,需要的朋友可以参考下
    2023-12-12
  • SpringBoot开发项目,引入JPA找不到findOne方法的解决

    SpringBoot开发项目,引入JPA找不到findOne方法的解决

    这篇文章主要介绍了SpringBoot开发项目,引入JPA找不到findOne方法的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • 图解程序员必须掌握的Java常用8大排序算法

    图解程序员必须掌握的Java常用8大排序算法

    本文以图片与文字结合的方式讲解了程序员必须掌握的Java常用8大排序算法:插入排序、冒泡排序、选择排序、希尔排序 、快速排序、归并排序、堆排序和LST基数排序,需要的朋友可以参考下
    2015-07-07

最新评论