多线程TCP服务器

相关Java类

Socket

public class Socket extends Object

  • 功能:TCP客户端套接字
  • 构造方法: Socket(InetAddress address, int port) 创建一个流套接字并将其连接到指定 IP 地址的指定端口号
  • 常用方法:
    1. getInetAddress 获得InetAddress的相关信息
    2. getInputStream 获得此TCP连接的输入流
    3. getOutPutStream 获得此TCP连接的输出流

ServerSocket

public class ServerSocket extends Object

  • 功能: TCP服务端套接字
  • 构造方法: ServerSocket(int port) 创建绑定到特定端口的服务器套接字。
  • 常用方法:
    1. accept 获得TCP连接的客户端的socket
    2. isClosed 获得ServerSocket的关闭状态

TCP服务器端

TcpServer.java

服务器端采用多线程的方式,每建立一个连接就启动一个java线程,发送图片给客户端,之后关闭此TCP连接

package cn.xidian.tcpSocket;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;

public class TcpServer extends Thread{
    Socket clientSocket;

    public TcpServer(Socket clientSocket) {
        super();
        this.clientSocket = clientSocket;
    }

    @Override
    public void run() {
        try {
            //获得客户端的ip地址和主机名
            String clientAddress = clientSocket.getInetAddress().getHostAddress();
            String clientHostName = clientSocket.getInetAddress().getHostName();
            System.out.println(clientHostName + "(" + clientAddress + ")" + " 连接成功!");
            System.out.println("Now, 传输图片数据...........");
            long startTime = System.currentTimeMillis();
            //获取客户端的OutputStream
            OutputStream out = clientSocket.getOutputStream(); 
            //传出图片数据
            FileInputStream in = new FileInputStream(new File("/home/gavinzhou/test.jpg")); 
            byte[] data = new byte[4096];
            int length = 0;
            while((length = in.read(data)) != -1){
                out.write(data, 0, length); //写出数据
            }
            long endTime = System.currentTimeMillis();
            //提示信息
            System.out.println(clientHostName + "(" + clientAddress + ")" + " 图片传输成功," + "用时:" + ((endTime-startTime)) + "ms");
            //关闭资源
            in.close();
            clientSocket.close();
            System.out.println("连接关闭!");
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

    public static void main(String[] args) throws IOException {
        //建立TCP连接服务,绑定端口
        ServerSocket tcpServer = new ServerSocket(9090);
        //接受连接,传图片给连接的客户端,每个TCP连接都是一个java线程
        while(true){
            Socket  clientSocket = tcpServer.accept();
            new TcpServer(clientSocket).start();
        }

    }

}

TCP客户端

TcpClient

package cn.xidian.tcpSocket;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.InetAddress;
import java.net.Socket;

public class TcpClient {

    public static void main(String[] args) throws IOException {
        // 建立TCP服务
        // 连接本机的TCP服务器
        Socket socket = new Socket(InetAddress.getLocalHost(), 9090);
        // 获得输入流
        InputStream inputStream = socket.getInputStream();
        // 写入数据
        FileOutputStream out = new FileOutputStream(new File("../save.jpg"));
        byte[] data = new byte[4096];
        int length = 0;
        while((length = inputStream.read(data)) != -1){
            out.write(data, 0, length);
        }
        //关闭资源
        out.close();
        socket.close();
    }


}

结果

首先,命令行启动服务器端,之后启动客户端,结果如下:

图片比较小,速度很快!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏蜉蝣禅修之道

java程序获取服务器响应报文

1113
来自专栏架构师之旅

【Java SE】Java NIO系列教程(十) DatagramChannel

Java NIO中的DatagramChannel是一个能收发UDP包的通道。因为UDP是无连接的网络协议,所以不能像其它通道那样读取和写入。它发送和接收的是数...

1695
来自专栏社区的朋友们

TAF 必修课(二):Reactor多线程模型

最近看了很多文章和分享,非常受益, 实习所做项目主要用到了TAF,有必要对之前的学习做个梳理和总结,网络线程模型及请求接收过程,必修亦为基础、通用,故取其名。

5390
来自专栏Java3y

WebSocket就是这么简单

前言 今天在慕课网上看到了Java的新教程(Netty入门之WebSocket初体验):https://www.imooc.com/learn/941 WebS...

6925
来自专栏xdecode

Netty与传统Server对比

前言 本文旨在介绍传统Socket服务端与NIO服务端的差异. 以餐厅服务员简单举例,每个客人对应一个请求. 传统Socket / OIO 1 public ...

2437
来自专栏java小白

java实现非对称加密

1673
来自专栏pangguoming

Java NIO框架Netty教程(一) – Hello Netty

先啰嗦两句,如果你还不知道Netty是做什么的能做什么。那可以先简单的搜索了解一下。我只能说Netty是一个NIO的框架,可以用于开发分布式的Java程序。具体...

1494
来自专栏架构师之旅

【Java SE】Java NIO系列教程(二) Channel

Java NIO的通道类似流,但又有些不同: 既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。 通道可以异步地读写。 通道中的数据总是要先读...

1868
来自专栏JAVA高级架构

从NIO到Netty开发

561
来自专栏青玉伏案

Java中的网络编程

​  Java中的网路编程主要是Java的Socket编程,属于JavaEE中的高级的部分,以下内容是对java网路编程的一个小结,代码都是经过编译调试的   ...

1766

扫码关注云+社区