TCP

客户端

先创建socket对象建立tcp客户端,明确服务端的地址和端口,必须与服务端对应,要不然对方收不到消息,就像快递填错了送货地址。

Socket s = new Socket("127.255.255.25", 10003);

然后建立起连接通道后就会出现socket的IO流,作为客户端我们是发送数据的,我们将数据发送到服务端让它去处理,所以我们获取的也就是OutPutStream,就是将数据写给服务端

OutputStream out = s.getOutputStream();

然后剩下的就是给服务端写数据了,这些操作其实就和IO流那块一样了,比如我们下面这样

out.write("hello,TCP来了".getBytes());

最后一定记得关闭socket资源

import java.io.IOException;
import java.io.OutputStream;
import java.net.Socket; public class TcpClient {
public static void main(String[] args) throws IOException, IOException { System.out.println("客户端运行。。。");
/**
* 需求:通过tcp传输数据发送给服务器
* 思路:
* 1、建立tcp客户端socket.明确服务端的地址和端口
* 2、如果通道建立成功就会出现socket io流
* 客户端需要做的就是获取socket流中输出流将数据发送目的地服务端
* 3、通过socket输出流将数据发送
* 4、关闭
*/
//1、建立tcp客户端socket.明确服务端的地址和端口 Socket s = new Socket("127.255.255.25", 10003); //2、如果通道建立成功就会出现socket io流 客户端需要做的就是获取socket流中输出流将数据发送目的地服务端
//3、通过socket输出流将数据发送 OutputStream out = s.getOutputStream();
out.write("hello,TCP来了".getBytes());
//4、关闭
s.close();
}
}

当你给服务端发送完数据后,有可能服务端还会给你回复一些数据,这时候在客户端还需要去接收服务端发送来的数据,只需要

InputStream in = s.getInputStream();

获取读取流,然后像IO流一样操作就可以读取返回的数据了

package tcp;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket; public class TCPClient2 { public static void main(String[] args) throws IOException{
System.out.println("客户端2 run...");
/**
* 案例二:实现客户端和服务端的收发过程
*/
//创建客户端socket对象,明确服务端地址和端口
Socket s = new Socket("127.255.255.25",10009); //发送数据通过socket输出流完成
OutputStream out = s.getOutputStream();
out.write("服务端,我来了".getBytes()); //读取服务器端返回的数据
InputStream in = s.getInputStream();
byte[] buf = new byte[1024];
int len= in.read(buf);
System.out.println(new String(buf,0,len));
// int len = 0;
// while((len = in.read(buf)) != -1)
// {
// System.out.println(new String(buf,0,len));
// } //关闭资源
s.close(); }
}

服务端

服务端要与客户端相连接,就必须创建一个服务端Serversocket对象,并明确端口,这个端口必须与客户端socket连接的端口一致,然后用一个socket对象去接收客户端的socket

 ServerSocket ss = new ServerSocket(10003);//创建服务端的socket。需要明确端口(监听一个端口),要不然客户端无法连接
Socket s = ss.accept();//服务端只要获取到连接过来的客户端就可以和指定的客户端通信了

这个接收客户端的socket对象s里面封装了不光数据内容,还有数据来源的主机IP等等信息。

然后获取流对象,对客户端发送来的数据进行读取

 InputStream in = s.getInputStream();

接下来就和IO操作一样,对数据进行处理即可。

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket; public class TcpServer {
public static void main(String[] args) throws IOException {
System.out.println("服务端。。。");
/**
* 需求:获取客户端的数据并显示在屏幕上
*
* 思路:
* 1、创建服务端的socket。需要明确端口(监听一个端口),要不然客户端无法连接
* 2、服务端只要获取到连接过来的客户端就可以和指定的客户端通信了
* 3、通过获取客户端的读取流对象读取客户端发来的数据
* 33、并显示在屏幕上
* 5、关闭资源
*/ //1、创建服务端的socket。需要明确端口(监听一个端口),要不然客户端无法连接 ServerSocket ss = new ServerSocket(10003); //2、服务端只要获取到连接过来的客户端就可以和指定的客户端通信了 Socket s = ss.accept();
String ip = s.getInetAddress().getHostAddress();
System.out.println(ip+"...connected");
//3、通过获取客户端的读取流对象读取客户端发来的数据
InputStream in = s.getInputStream(); //33、并显示在屏幕上
byte[] buf = new byte[1024];
int len = 0;
while((len = in.read(buf)) != -1)
{
System.out.println(new String(buf, 0, len));
} //5、关闭资源
s.close();
//ss.close(); 这一般不关
}
}

一般服务端接收到数据之后,它还会给客户端返回一些反馈信息,我们可以继续获取读写流,对客户端进行写入操作,即反馈信息。

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket; public class TcpServer2 {
public static void main(String[] args) throws IOException { System.out.println("服务端2 run...");
/**
* 案例二:实现客户端和服务端的收发过程
* 服务器端
*/ //创建tcp服务端socket明确端口
ServerSocket ss = new ServerSocket(10009);
while(true)
{
//获取客户端对象
Socket s = ss.accept();
System.out.println(s.getInetAddress().getHostAddress()+"...connected"); //读取客户端发送过来的数据
InputStream in = s.getInputStream();
byte[] buf = new byte[1024];
int len = in.read(buf); //读取到数据之前,线程处于阻塞状态
System.out.println(new String(buf,0,len));
// int len = 0;
// while((len = in.read(buf)) != -1)
// {
// System.out.println(new String(buf,0,len));
// }
//
// System.out.println("阻塞了吗?"); //给客户端回馈数据
OutputStream out = s.getOutputStream();
out.write("客户端。我已收到。哦耶!".getBytes()); //关闭客户端
s.close();
} //关闭服务端
//ss.close(); 如果是不断的获取客户端,就不用关闭服务器
}
}

结果演示:

先开启服务端



服务端收到数据



客户端收到反馈

TCP方式的传输的更多相关文章

  1. UDP方式的传输

    UDP 部分内容需要查文档学习,我们需要了解下面的两个类:java.net.DatagramSocket和java.net.DatagramPacket java.net.DatagramSocket ...

  2. 网络层、传输层、应用层、端口通信协议编程接口 - http,socket,tcp/ip 网络传输与通讯知识总结

    引: http://coach.iteye.com/blog/2024511 什么是TCP和UDP,以及二者区别是什么? TCP的全称为传输控制协议.这种协议可以提供面向连接的.可靠的.点到点的通信. ...

  3. 用vlc搭建简单流媒体服务器(UDP和TCP方式)

    .UDP(legacy)传统模式 .RTP方式 .RTSP方式 RTSP方式是通过RTP进行流媒体数据的传输的,VLC的实现也是基于UDP的.这种方式网上的参考资料比较多,我就不截图了,直接叙述命令行 ...

  4. 转 RTSP客户端模拟器(TCP方式,Python实现)

    转自: http://www.cnblogs.com/MikeZhang/archive/2012/10/29/rtspTcpClient_DSS_20121029.html 由于某种需求,工作中需要 ...

  5. WCF的Restful和TCP方式调用性能比较

    1. 实验背景关于WCF提供分布式访问服务,最常用的两种方式Restful方式和Tcp方式,在本地测试了一把.结果显示,还是Rest方式,在压力测试下,性能最佳.而且处于跨平台的考虑,和自动化测试方便 ...

  6. Android开发:如何实现TCP和UDP传输

    TCP和UDP在网络传输中非常重要,在Android开发中同样重要. 首先来看一下什么是TCP和UDP. 什么是TCP? TCP:Transmission Control Protocol 传输控制协 ...

  7. 【转】使用TCP协议连续传输大量数据时,是否会丢包,应如何避免?

    使用TCP协议连续传输大量数据时,是否会丢包,应如何避免? 比如发送文件.记得有人提过可能会发生什么堆栈溢出.怎样避免呢?是不是可以收到数据后发送确认包,收到确认包后再继续发送.或是发送方发送了一些数 ...

  8. Android如何实现TCP和UDP传输

    TCP和UDP在网络传输中非常重要,在Android开发中同样重要. 首先我们来看一下什么是TCP和UDP. 什么是TCP? TCP:Transmission Control Protocol 传输控 ...

  9. ffmpeg强制使用TCP方式读取rtsp流

    ffmpeg强制使用TCP方式处理rtsp流,参考网上资料,得知可以使用如下命令: “ffmpeg -rtsp_transport tcp -i rtsp://admin.......” 可以是使用抓 ...

随机推荐

  1. 【LeetCode】79-单词搜索

    题目描述 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中 "相邻" 单元格是那些水平相邻或垂直相邻的单元格.同一 ...

  2. String对象为什么不可变

    转载:https://www.cnblogs.com/leskang/p/6110631.html 一.什么是不可变对象? As we all know, 在Java中, String类对象是不可变的 ...

  3. 062 Python必备库-从Web解析到网络空间

    目录 一.概述 二.Python库之网络爬虫 2.1 Requests 2.2 Scrapy 2.3 pyspider 三.Python库之Web信息提取 3.1 Beautiful Soup 3.2 ...

  4. FreeSql (十七)联表查询

    FreeSql在查询数据下足了功能,链式查询语法.多表查询.表达式函数支持得非常到位. IFreeSql fsql = new FreeSql.FreeSqlBuilder() .UseConnect ...

  5. 教程 —— 如何在自己的应用集成superset

    Superset 是apache的一个孵化项目,定位为一款现代的,准商用BI系统 superset Apache Superset (incubating) is a modern, enterpri ...

  6. ASP.NET Core 2.2 : 二十一. 内容协商与自定义IActionResult和格式化类

    上一章的结尾留下了一个问题:同样是ObjectResult,在执行的时候又是如何被转换成string和JSON两种格式的呢? 本章来解答这个问题,这里涉及到一个名词:“内容协商”.除了这个,本章将通过 ...

  7. apache ignite系列(五):分布式计算

    ignite分布式计算 在ignite中,有传统的MapReduce模型的分布式计算,也有基于分布式存储的并置计算,当数据分散到不同的节点上时,根据提供的并置键,计算会传播到数据所在的节点进行计算,再 ...

  8. 松软科技课堂:sqlserver--数据类型

    SQL Server 数据类型(文章来源:松软科技www.sysoft.net.cn) Character 字符串: 数据类型 描述 存储 char(n) 固定长度的字符串.最多 8,000 个字符. ...

  9. 详细的App推广前的准备工作

    App开发完成后,推广App自然就成为下一步工作的重点.兵马未动,粮草先行,这里为大家整理了一份App推广前需要准备一些事项,希望能给正在准备开展App推广的小伙伴们一些帮助. 众所周知,App推广的 ...

  10. NPOI 导出添加批注功能

    这个问题在网上搜,都是说如下即可: //添加批注HSSFPatriarch patr = (HSSFPatriarch)sheet.CreateDrawingPatriarch();HSSFComme ...