1、TCP通信的概述

  (1)TCP通信同UDP通信一样,都能实现两台计算机之间的通信,通信的两端都需要创建socket对象;

  (2)区别在于:

    ①UDP中只有发送端和接收端,不区分客户端与服务器端,计算机之间可以任意地发送数据;

    ②TCP通信是严格区分客户端与服务器端的。

  (3)在通信时,必须先由客户端去连接服务器端才能实现通信,服务器端不可以主动连接客户端,并且服务器端程序需要事先启动,等待客户端的连接;

  (4)在JDK中提供了两个类用于实现TCP程序,一个是ServerSocket类,用于表示服务器端,一个是Socket类,用于表示客户端;  

  (5)通信时,首先创建代表服务器端的ServerSocket对象,该对象相当于开启一个服务,并等待客户端的连接,然后创建代表客户端的Socket对象向服务器端发出连接请求,服务器端响应请求,两者建立连接开始通信

2、ServerSocket

  (1)ServerSocket对象负责监听某台计算机的某个端口号,在创建ServerSocket对象后,需要继续调用该对象的accept()方法,接收来自客户端的请求;

  (2)当执行了accept()方法之后,服务器端程序会发生阻塞,直到客户端发出连接请求,accept()方法才会返回一个Scoket对象用于和客户端实现通信,程序才能继续向下执行。

3、Socket

  (1)JDK提供了一个Socket类,用于实现TCP客户端程序;

  (2)在Socket类的常用方法中,getInputStream()和getOutStream()方法分别用于获取输入流和输出流。当客户端和服务端建立连接后,数据是以IO流的形式进行交互的,从而实现通信。

4、简单的TCP网络程序

  (1)首先需要实现服务器端程序

 import java.io.IOException;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket; /*
* TCP 服务器端
*
* 1,创建服务器ServerSocket对象(指定服务器端口号)
* 2,开启服务器了,等待客户端的连接,当客户端连接后,可以获取到连接服务器的客户端Socket对象
* 3,给客户端反馈信息
* 4,关闭流资源
*/
public class TCPServer {
public static void main(String[] args) throws IOException {
// 1,创建服务器ServerSocket对象(指定服务器端口号)
ServerSocket ss = new ServerSocket(8888);
// 2,开启服务器了,等待客户端的连接,当客户端连接后,可以获取到连接服务器的客户端Socket对象
Socket s = ss.accept();
// 3,给客户端反馈信息
/*
* a,获取客户端的输出流 b,在服务端端,通过客户端的输出流写数据给客户端
*/
// a,获取客户端的输出流
OutputStream out = s.getOutputStream();
// b,在服务端端,通过客户端的输出流写数据给客户端
out.write("你已经连接上了服务器".getBytes());
// 4,关闭流资源
out.close();
s.close();
// ss.close(); 服务器流 通常都是不关闭的
}
}

  (2)完成了服务器端程序的编写,接下来编写客户端程序

 import java.io.IOException;
import java.io.InputStream;
import java.net.Socket; /*
* TCP 客户端
*
* 1,创建客户端Socket对象,(指定要连接的服务器地址与端口号)
* 2,获取服务器端的反馈回来的信息
* 3,关闭流资源
*/
public class TCPClient {
public static void main(String[] args) throws IOException {
// 1,创建客户端Socket对象,(指定要连接的服务器地址与端口号)
Socket s = new Socket("192.168.0.4", 8888);
// 2,获取服务器端的反馈回来的信息
InputStream in = s.getInputStream();
// 获取获取流中的数据
byte[] buffer = new byte[1024];
// 把流中的数据存储到数组中,并记录读取字节的个数
int length = in.read(buffer);
// 显示数据
System.out.println(new String(buffer, 0, length));
// 3,关闭流资源
in.close();
s.close();
}
}

  运行结果:

  

5、文件上传

  (1)目前大多数服务器都会提供文件上传的功能,由于文件上传需要数据的安全性和完整性,很明显需要使用TCP协议来实现;

  (2)首先编写服务器端程序,用来接收图片

 import java.io.BufferedOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.ServerSocket;
import java.net.Socket; /*
* 文件上传 服务器端
*
*/
public class TCPServer {
public static void main(String[] args) throws IOException {
// 1,创建服务器,等待客户端连接
ServerSocket serverSocket = new ServerSocket(8888);
Socket clientSocket = serverSocket.accept();
// 显示哪个客户端Socket连接上了服务器
InetAddress ipObject = clientSocket.getInetAddress();// 得到IP地址对象
String ip = ipObject.getHostAddress(); // 得到IP地址字符串
System.out.println("测试已连接" + "IP:" + ip); // 7,获取Socket的输入流
InputStream in = clientSocket.getInputStream();
// 8,创建目的地的字节输出流 D:\\upload\\192.168.0.4(1).jpg
BufferedOutputStream fileOut = new BufferedOutputStream(
new FileOutputStream("D:\\upload\\192.168.0.4(1).png"));
// 9,把Socket输入流中的数据,写入目的地的字节输出流中
byte[] buffer = new byte[1024];
int len = -1;
while ((len = in.read(buffer)) != -1) {
// 写入目的地的字节输出流中
fileOut.write(buffer, 0, len);
} // -----------------反馈信息---------------------
// 10,获取Socket的输出流, 作用:写反馈信息给客户端
OutputStream out = clientSocket.getOutputStream();
// 11,写反馈信息给客户端
out.write("图片上传成功".getBytes()); out.close();
fileOut.close();
in.close();
clientSocket.close();
// serverSocket.close();
}
}

  (3)编写客户端,完成上传图片

 import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket; /*
* 文件上传 客户端
*
* public void shutdownOutput() 禁用此Socket的输出流,间接的相当于告知了服务器数据写入完毕
*/
public class TCPClient {
public static void main(String[] args) throws IOException {
// 2,创建客户端Socket,连接服务器
Socket socket = new Socket("192.168.0.4", 8888);
// 3,获取Socket流中的输出流,功能:用来把数据写到服务器
OutputStream out = socket.getOutputStream();
// 4,创建字节输入流,功能:用来读取数据源(图片)的字节
BufferedInputStream fileIn = new BufferedInputStream(
new FileInputStream("D:\\Java\\00Base\\googlelogo.png"));
// 5,把图片数据写到Socket的输出流中(把数据传给服务器)
byte[] buffer = new byte[1024];
int len = -1;
while ((len = fileIn.read(buffer)) != -1) {
// 把数据写到Socket的输出流中
out.write(buffer, 0, len);
}
// 6,客户端发送数据完毕,结束Socket输出流的写入操作,告知服务器端
socket.shutdownOutput(); // -----------------反馈信息---------------------
// 12,获取Socket的输入流 作用: 读反馈信息
InputStream in = socket.getInputStream();
// 13,读反馈信息
byte[] info = new byte[1024];
// 把反馈信息存储到info数组中,并记录字节个数
int length = in.read(info);
// 显示反馈结果
System.out.println(new String(info, 0, length)); // 关闭流
in.close();
fileIn.close();
out.close();
socket.close();
}
}

00107_TCP通信的更多相关文章

  1. 理解加密算法(三)——创建CA机构,签发证书并开始TLS通信

    接理解加密算法(一)--加密算法分类.理解加密算法(二)--TLS/SSL 1 不安全的TCP通信 普通的TCP通信数据是明文传输的,所以存在数据泄露和被篡改的风险,我们可以写一段测试代码试验一下. ...

  2. 笔记:Binder通信机制

    TODO: 待修正 Binder简介 Binder是android系统中实现的一种高效的IPC机制,平常接触到的各种XxxManager,以及绑定Service时都在使用它进行跨进程操作. 它的实现基 ...

  3. .NET 串口通信

    这段时间做了一个和硬件设备通信的小项目,涉及到扫描头.输送线.称重机.贴标机等硬件.和各设备之间通信使用的是串口或网络(Socket)的方式.扫描头和贴标机使用的网络通信,输送线和称重机使用的是串口通 ...

  4. MVVM模式解析和在WPF中的实现(五)View和ViewModel的通信

    MVVM模式解析和在WPF中的实现(五) View和ViewModel的通信 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 M ...

  5. 多线程的通信和同步(Java并发编程的艺术--笔记)

    1. 线程间的通信机制 线程之间通信机制有两种: 共享内存.消息传递.   2. Java并发 Java的并发采用的是共享内存模型,Java线程之间的通信总是隐式执行,通信的过程对于程序员来说是完全透 ...

  6. 搭建QQ聊天通信的程序:(1)基于 networkcomms.net 创建一个WPF聊天客户端服务器应用程序 (1)

    搭建QQ聊天通信的程序:(1)基于 networkcomms.net 创建一个WPF聊天客户端服务器应用程序 原文地址(英文):http://www.networkcomms.net/creating ...

  7. 高性能 TCP/UDP/HTTP 通信框架 HP-Socket v4.1.1

    HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP/HTTP 通信系统,提供 C/ ...

  8. TCP通信

    //网络套接字编程实例,服务器端,TCP通信. #include <WinSock2.h> #pragma comment(lib,"ws2_32.lib") #inc ...

  9. JAVA通信系列一:Java Socket技术总结

    本文是学习java Socket整理的资料,供参考. 1       Socket通信原理 1.1     ISO七层模型 1.2     TCP/IP五层模型 应用层相当于OSI中的会话层,表示层, ...

随机推荐

  1. [HNOI2006]潘多拉的宝盒

    https://www.zybuluo.com/ysner/note/1250303 题面 给定\(s\)个自动机,如果某个自动机\(A\)能产生的所有串都能在自动机\(B\)中产生(即走相同\(0/ ...

  2. 使用 Jenkins + GitHub + Nginx + HTTPS 搭建静态网站

    参考https://www.imooc.com/article/20079 http://www.haoduoyu.cc/

  3. go多进程

    package main import "fmt" import "time"func loop() { for i := 0; i < 10; i++ ...

  4. Xampp mysql无法启动的解决方案

    如果出现mysql 无法启动表明在安装xampp 前已经安装了mysql,造成mysql服务无法启动. 19:06:33  [mysql] MySQL Service detected with wr ...

  5. centos安装 memcached

    .安装 yum -y update yum install -y libevent libevent-devel yum install -y memcached 2.配置 vi /etc/sysco ...

  6. 4CSS颜色和背景

    ---------------------------------------------------------------------------------------------------- ...

  7. Winform中Treeview控件失去焦点,将选择的节点设置为高亮显示 (2012-07-16 13:47:07)转载▼

    Winform中Treeview控件失去焦点,将选择的节点设置为高亮显示 (2012-07-16 13:47:07)转载▼标签: winform treeview drawnode Treeview控 ...

  8. Android 从服务器获取时间戳转换为年月日

    用JAVA相关类转换.代码如下: Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(NumberUtils.ge ...

  9. 提高mysql千万级大数据SQL查询优化几条经验

    凯哥java                             微信号                             kaigejava 功能介绍                    ...

  10. 3.用Redis Desktop Manager连接Redis(CentOS)

    Redis Desktop Manager是Redis图形化管理工具,方便管理人员更方便直观地管理Redis数据. 然而在使用Redis Desktop Manager之前,有几个要素需要注意: 一. ...