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();

    }
}
相关推荐
fy zs1 天前
应用层自定义协议和序列化
linux·网络·c++
ba_pi1 天前
每天写点什么2026-01-10-深度学习和网络原理
网络·人工智能·深度学习
王夏奇1 天前
python在汽车电子行业中应用2—具体包的介绍和使用
网络·python·汽车
cnstartech1 天前
esxi-vmware 虚拟机互相打开
linux·运维·服务器
不知疲倦的仄仄1 天前
第四天:Netty 核心原理深度解析&EventLoop、Future/Promise 与 Pipeline
linux·服务器·网络
橘颂TA1 天前
【Linux 网络编程】网络是怎么 “跑” 起来的?从协议入门到 TCP/ IP 模型的底层逻辑
linux·运维·服务器·网络
我的golang之路果然有问题1 天前
python中 unicorn 热重启问题和 debug 的 json
java·服务器·前端·python·json
MOON404☾1 天前
004.漏洞分析与利用
前端·网络·网络安全·系统安全·firefox
AC赳赳老秦1 天前
医疗数据安全处理:DeepSeek实现敏感信息脱敏与结构化提取
大数据·服务器·数据库·人工智能·信息可视化·数据库架构·deepseek
AI科技星1 天前
能量绝对性与几何本源:统一场论能量方程的第一性原理推导、验证与范式革命
服务器·人工智能·科技·线性代数·算法·机器学习·生活