tcp协议相对于udp更加安全。

首先看一下需求:服务器端开启,多个客户端同时向服务器发送数据,看哪个客户端先到达。

说明:这里我开启三个电脑实验,一台电脑写服务器端的程序,两台电脑开客户端的程序。服务器先开启程序,客户端同时开启发送数据。

客户端的程序:

import java.io.IOException;
import java.io.OutputStream;
import java.net.Socket; /*
* TCP协议发送数据:
* A:创建发送端的Socket对象
* 这一步如果成功,就说明连接已经建立成功了。
* B:获取输出流,写数据
* C:释放资源
*
* 连接被拒绝。TCP协议一定要先开服务器。保证数据被收到,要先开始服务器端
* java.net.ConnectException: Connection refused: connect
*/
public class ClientDemo {
public static void main(String[] args) throws IOException {
// 创建发送端的Socket对象
// Socket(InetAddress address, int port)
// Socket(String host, int port)
Socket s = new Socket("192.168.1.105", 8888);//这个ip是服务器端的ip,和服务器端的端口号 // 获取输出流,写数据
// Socket类下面的方法:public OutputStream getOutputStream()
OutputStream os = s.getOutputStream();
os.write("hello,tcp,我来了".getBytes()); // 释放资源
s.close();
}
}

然后写出服务器端的程序:

package cn.itcast_06;

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket; /*
* TCP协议接收数据:
* A:创建接收端的Socket对象
* B:监听客户端连接。返回一个对应的Socket对象
* C:获取输入流,读取数据显示在控制台
* D:释放资源
*/
public class ServerDemo {
public static void main(String[] args) throws IOException {
// 创建接收端的Socket对象
// ServerSocket(int port)
ServerSocket ss = new ServerSocket(8888); // 监听客户端连接。返回一个对应的Socket对象
// public Socket accept()
Socket s = ss.accept(); // 侦听并接受到此套接字的连接。此方法在连接传入之前一直阻塞。直到发送端有数据创建Socket链接并发送数据 // 获取输入流,读取数据显示在控制台
InputStream is = s.getInputStream(); byte[] bys = new byte[1024];
int len = is.read(bys); // 阻塞式方法,只有等到流对象有了数据才能读取
String str = new String(bys, 0, len); String ip = s.getInetAddress().getHostAddress();//获取客户端ip地址 System.out.println(ip + "---" + str); // 释放资源
s.close();//防止多个客户端时出问题。因为不同的客户端应该对应不同的socket对象。
// ss.close(); //这个不应该关闭,因为有多个客户端的时候,一个客户端获取完数据,此时服务器却关闭了,则其他客户端就没法在服务器获取数据。
}
}

对于阻塞原理,以及遇到的问题。会在以后来分析。

05-08 08:43