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

    }
}
相关推荐
草莓熊Lotso1 小时前
Git 分支管理:从基础操作到协作流程(本地篇)
大数据·服务器·开发语言·c++·人工智能·git·sql
江湖有缘1 小时前
Linux系统之htop命令基本使用
linux·运维·服务器
上海云盾安全满满3 小时前
高防 IP 是如何帮助数藏行业防刷
网络·网络协议·tcp/ip
qq_401700415 小时前
嵌入式用Unix时间的优势及其C语言转换
服务器·c语言·unix
xu_yule7 小时前
Linux_12(进程信号)内核态和用户态+处理信号+不可重入函数+volatile
linux·运维·服务器
虾..7 小时前
Linux 环境变量&&进程优先级
linux·运维·服务器
多多*8 小时前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
p***43489 小时前
Rust网络编程模型
开发语言·网络·rust
NewCarRen9 小时前
汽车网络安全管理系统的需求分析及潜在框架设计
网络·汽车网络安全
捷米研发三部9 小时前
CC-Link转Modbus TCP协议转换网关实现三菱 PLC与传感器通讯在快递分拣中心的应用案例
网络·网络协议