Tcp通讯协议
了解了Udp通讯协议之后,我们再认识一个常用的通讯协议:Tcp
Tcp传输特点:
--依赖于Socket和ServerSocket对象
--建立客户端和服务端
--建立连接后,通过Socket中的 IO 流进行数据的传输
--关闭Scoket
下面通过一个简单的例子认识一下:
--tcp分客户端和服务端
--客户端对应的对象是Socker
服务端对应的对象是ServerSocket
//客户端:
package com.shindo.java.tcp;
import java.io.*;
import java.net.*; /**
* 客户端:
* 通过查询Socket对象,发现在该对象建立时,就可以去连接指定的主机,
* 因为Tcp是面向连接的,所以在建立Socket服务时,就要有服务端存在,并连接成功,形成通路后,在该通道进行数据传输
*
* 需求:给服务端发送一个文本数据
*/
public class TcpClient {
public static void main(String[] args)throws Exception{
//创建客户端的Socket服务,指定目的主机和端口
Socket s = new Socket("127.0.0.1",11012); //为了发送数据,应获取Socket流中的输出流
OutputStream out = s.getOutputStream();//使用字节流 out.write("This's the first Tcp test Demo".getBytes()); //因为流是通过Socket获得的,所有一旦Socket关闭,流也随之关闭
s.close();
}
}
//服务端:
package com.shindo.java.tcp;
import java.io.*;
import java.net.*;
/**
* 需求:定义端点接收数据,并打印在控制台上
*
* 1、简历ServerSocket服务,并监听一个端口
* 2、获取连接过来的客户端对象
* 通过ServerSocket的accept()方法,没有连接就会等,所以这个方法是阻塞的。
* 3、客户端如果发过来数据,那么服务端要使用对应的客户端对象,并获取到该客户端对象的读取流
* 来读取客户端发送过来的数据,并打印控制台;
* 4、关闭服务端(可选)
*/
public class TcpServer {
public static void main(String[] args){
try {
//简历服务端Socket服务,并监听一个端口
ServerSocket ss = new ServerSocket(11012); //通过accept()方法获取连接过来的客户端对象
Socket s = ss.accept(); String ip = s.getInetAddress().getHostAddress();
System.out.println(ip + ".........is connected"); //使用客户端对象的读取流读取客户端发送过来的数据
InputStream in = s.getInputStream();//实际上是一个网络流 byte[] buf = new byte[1024]; int len = in.read(buf);
System.out.println(new String(buf,0,len)); s.close();
} catch (Exception e) {
e.printStackTrace();
}
} }
============================优雅的分割线============================
上面这两个例子,实现了客户端向服务端发送文本信息,服务端收到并将其打印到控制台。
现在我们再对上面两个程序进行一些改造,让服务端接收到客户端的信息后,打印到控制台,并响应信息给客户端;客户端也将服务端响应的信息打印到控制台:
//客户端:
package com.shindo.java.tcp;
import java.io.*;
import java.net.*; public class TcpClient2 {
public static void main(String[] args){
try {
Socket s = new Socket("127.0.0.1",11012); //发送文本数据给客户端
OutputStream out = s.getOutputStream();
out.write("This's the better TcpClient test Demo".getBytes()); //读取客户端响应信息
InputStream in = s.getInputStream();
byte[] buf = new byte[1024];
int len = in.read(buf);
System.out.println(new String(buf,0,len)); s.close(); } catch (Exception e) {
e.printStackTrace();
}
}
}
//服务端:
package com.shindo.java.tcp;
import java.io.*;
import java.net.*; public class TcpServer2 {
public static void main(String[] args){
try {
//创建服务端,并监听一个端口
ServerSocket ss = new ServerSocket(11012);
Socket s = ss.accept(); //获取请求的客户端ip,并打印控制台
String ip = s.getInetAddress().getHostAddress();
System.out.println(ip + "........... is connected"); //获取客户端发送过来的数据,并打印控制台
InputStream in = s.getInputStream();
byte[] buf = new byte[1024];
int len = in.read(buf);
System.out.println(new String(buf,0,len)); //发送响应信息给客户端
OutputStream out = s.getOutputStream();
out.write("welcome, client !".getBytes()); s.close();
ss.close(); } catch (Exception e) {
e.printStackTrace();
} }
}
效果如下:
客户端接收到服务到响应:

服务端接收到客户端发过来的数据:

Tcp通讯协议的更多相关文章
- java基础55 UDP通讯协议和TCP通讯协议
本文知识点(目录): 1.概述 2.UDP通讯协议 3.TCPP通讯协议 1.概述 1.在java中网络通讯作为Socket(插座)通讯,要求两台都必须安装socket. 2.不同的 ...
- C#中的TCP通讯与UDP通讯
最近做了一个项目,主要是给Unity3D和实时数据库做通讯接口.虽然方案一直在变:从开始的UDP通讯变为TCP通讯,然后再变化为UDP通讯;然后通讯的对象又发生改变,由与数据库的驱动进行通讯(主动推送 ...
- 异常和TCP通讯
第七章 异常处理 * 异常处理机制中的try-catch * 语法: * try{ * 代码片段 * }catch(XXXException e){ * 当try中的代码片段出现了XXXExcepti ...
- GCDAsyncSocket类库,IOS下TCP通讯使用心得
关于在IOS下使用Socket进行通讯的技术文章也许诺很久了,今日又是一个还债的日子,网上虽然很多介绍过AsyncSocket或GCDAsyncSocket的文章,但其实就那么一两篇大部分都是转载,于 ...
- TCP/IP 中文译名为传输控制协议/因特网互联协议,又叫网络通讯协议
原文地址:http://hi.baidu.com/albyuyrgqgbbhoq/item/65006d2d002ab33195f62ba1 TCP/IP(Transmission Control P ...
- QQ--基于TCP/UDP协议的通讯原理
QQ是一个基于TCP/UDP协议的通讯软件 发送消息的时候是UDP打洞,登陆的时候使用HTTP~因为登陆服务器其实就是一个HTTP服 务器,只不过不是常用的那些,那个服务器是腾讯自行开发的! 一 ...
- JAVA之旅(三十二)——JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用
JAVA之旅(三十二)--JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用 GUI写到一半电脑系统挂了,也就算了,最多GUI还有一个提示框和实例, ...
- linux shell 脚本实现tcp/upd协议通讯(重定向应用)
linux shell 脚本实现tcp/upd协议通讯(重定向应用) http://www.cnblogs.com/chengmo/archive/2010/10/22/1858302.html
- Shell 脚本实现TCP/UDP协议通讯
Shell 脚本实现TCP/UDP协议通讯 http://www.cnblogs.com/occult/archive/2012/12/25/2832183.html
随机推荐
- 【转】WCF、WebAPI、WCFREST、WebService之间的区别
在.net平台下,有大量的技术让你创建一个HTTP服务,像Web Service,WCF,现在又出了Web API.在.net平台下,你有很多的选择来构建一个HTTP Services.我分享一下我对 ...
- 字典树-百度之星-Xor Sum
Xor Sum Problem Description Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包括了N个正整数,随后 Prometheu ...
- 升级IOS9,提示滑动升级,卡在password锁屏界面,无反应了
注:升级之前一定要把锁屏password取消掉 若遇上述问题.可通过进入DFU 模式解决 进入DFU具体步骤.(进入成功后,屏幕为全黑) 注:在进入DFU操作时务必与电脑连接好数据线. 1.按住pow ...
- Apache与Tomcat区别联系
监控服务(师傅让我监控Tomcat,我知道Apache,所以以为他两是一个东东.结果半天就没有找到Tomcat的服务进程,还理直气壮的说:找不到Apache......希望这篇简单的,白话分析,能让还 ...
- css导航条
#nav ul { display: none; position: absolute; padding-top: 0px;} #nav li:hover ul { display: block;}
- Mysql学习(慕课学习笔记2)数据库的创建与删除
创建数据库 { } 必选 | 从前后做选择 [ ] 可选 Create {database | schema} [if not exists] db_name [default] charact ...
- include 和 require 的区别
1. 首先不去介绍大家都知道的区别,百度上都进行了详细的说明,对于返回值的方面大家都很少提到. include 和 require 还有一个区别就是是否具有返回值.参见手册 对include 加载文件 ...
- Scala学习文档-样本类与模式匹配(match,case,Option)
样本类:添加了case的类便是样本类.这种修饰符可以让Scala编译器自动为这个类添加一些语法上的便捷设定. //样本类case class //层级包括一个抽象基类Expr和四个子类,每个代表一种表 ...
- EF有外键的查询
modelBuilder.Entity<ActionMenu>().ToTable("ActionMenu"); modelBuilder.Entity<Acti ...
- Spring Data JPA之Hello World
Spring Data Jpa 配置 使用 Spring Data JPA 进行持久层开发需要的四个步骤: 1.配置 Spring 整合 JPA 2.在 Spring 配置文件中配置 Spring D ...