02-TCP多发多收

要求:客户端与服务端建立TCP连接,客户端与服务端实现多发多收

实现方式:

客户端:建立连接--客户端创建Socket通信管道,并传参目的服务器IP与端口号;

发送数据--客户端首先从Socket通信管道得到一个字节输出流,再包装成打印流; 然后死循环输入 将键盘输入信息传给println()并flush();

服务端:监听连接--服务端创建serversocket 调用其accept()监听,并传给 Socket通信管道; 将字节流转为字符流再转为缓冲流;并死循环打印;

java 复制代码
package com.itheima.b01TCPTest1;

import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.net.InetAddress;
import java.net.Socket;
import java.util.Scanner;

//多次发送数据
public class Client {
    public static void main(String[] args) throws IOException {
        System.out.println("===客户端启动===");

        //1、创建Socket通信管道,请求服务端的连接。 参数为服务端IP与端口号
        Socket socket = new Socket(InetAddress.getLocalHost(),10000);

        //2、从Socket通信管道得到一个字节输出流,负责发送 字节数据
        OutputStream os = socket.getOutputStream();
        //把低级的字节流 包装成 打印流
        PrintStream ps = new PrintStream(os);
        Scanner sc = new Scanner(System.in);
        while(true){
            System.out.println("输入想要发送的信息:");
            String msg = sc.nextLine();
            ps.println(msg);
            ps.flush();
        }
        //3、释放资源 撤销连接
        //socket.close();
    }
}
java 复制代码
package com.itheima.b01TCPTest1;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;

//多次接收数据 并打印
public class Server {
    public static void main(String[] args) throws IOException {
        System.out.println("===启动服务端===");
        //1、创建ServerSocket对象 注册端口
        ServerSocket ss = new ServerSocket(10000);

        //2、调用accept方法,等待客户端的Socket连接请求,建立Socket通信管道
        Socket socket = ss.accept();

        //3、从Socket通信管道得到一个字节输入流,实现多次接收数据 缓冲流 字符流 字节流
        BufferedReader bfr = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        String msg;
        while((msg = bfr.readLine()) != null){
            System.out.println(socket.getRemoteSocketAddress() + "传输信息:" + msg);
        }

        //4、关闭通道 关闭服务器 释放资源

        //socket.close();
        //ss.close();

    }
}
相关推荐
AC赳赳老秦1 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
夏日听雨眠2 小时前
LInux(逻辑地址与物理地址的区别,文件描述符,lseek函数)
linux·运维·网络
ydyd202604213 小时前
制造业数字化干货:设备巡检、报修、保养一体化管理流程拆解
网络
Hali_Botebie3 小时前
【图卷积网络】GCN是AXΘ 和CNN是AX
网络·人工智能·cnn
IpdataCloud3 小时前
高并发场景下IP数据接口怎么选?从QPS到离线库的完整选型指南
网络·网络协议·tcp/ip
CableTech_SQH4 小时前
企业园区网络突然中断排查时间影响生产?综合布线运维管理解决方案分析
网络
難釋懷4 小时前
Redis网络模型-IO多路复用模型-poll模式
网络·数据库·redis
treesforest5 小时前
IP精准定位服务:从城市轮廓到街道坐标,技术如何重塑空间感知
网络·数据库·网络协议·tcp/ip·ip
大明者省5 小时前
宝塔开了端口,Ubuntu 还得开相应端口才能打通
服务器·数据库·ubuntu
平行侠5 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法