JAVA - Socket

从开学到现在 也学了三个月时间的java了,一直在 在 语法和基本使用上周旋,井底之娃一枚。 这两天 有学长指点,花了两天的时间 学习了java多线程和socket的简单使用,利用周末时间 自己写了个 Socket 多客户端的 Demo,有很多不成熟或者不好的 地方,请指正。

TCP 的 Java 支持

协议相当于相互通信的程序间达成的一种约定,它规定了分组报文的结构、交换方式、包含的意义以及怎样对报文所包含的信息进行解析,TCP/IP 协议族有 IP 协议、TCP 协议和 UDP 协议。现在 TCP/IP 协议族中的主要 socket 类型为流套接字(使用 TCP 协议)和数据报套接字(使用 UDP 协议)。

Socket套接字 是面向连接的通信,基于TCP/IP协议提供了稳定的支持(Ps: TCP/IP 传输效率低于 UDP),TCP/IP 提供了Socket和Serversocket两个类, 使用 Serversocket 实例来监听端口是否 有客户端请求,并通过 accept()方法 来返回一个Socket 实例,客户端的socket和服务端的socket 就这样建立了连接,每个socket 有自己的io流 ,那么服务端的输入流对应客户端的输出流,客户端的输出流对应服务端的输入流,在这里输入流 我们采用(BufferedReader)包装流,输入采用(PrintStream)包装流,通过包装流 包装 输入输初流,可以方便程序数据的使用。

典型的 TCP 服务端执行如下两步操作:

创建一个 ServerSocket 实例并指定本地端口,用来监听客户端在该端口发送的 TCP 连接请求;

  1. 重复执行:

    • 调用 ServerSocket 的 accept()方法以获取客户端连接,并通过其返回值创建一个 Socket 实例;

    • 为返回的 Socket 实例开启新的线程,并使用返回的 Socket 实例的 I/O 流与客户端通信; 通信完成后,使用 Socket 类的 close()方法关闭该客户端的

套接字连接。

好了话不多说,下面贴程序。

***服务端代码***

 package socket多客户端;

 import java.io.IOException;
import java.net.*;
import java.util.ArrayList;
public class Server { private static ArrayList<Thread_Client> list = new ArrayList<>(); private static final int PORT = 6789;
private static ServerSocket serverSocket;
private static Socket socket; static void send(String string){ // 使用 for 循环 , 遍历Arraylist 广播某客户端传来的消息
for(Thread_Client thread_Client : list){
// 调用 子线程的 send 方法
thread_Client.send(string);
} } public static void main(String[] args) { System.out.println("服务端开始运行..."); try { serverSocket = new ServerSocket(PORT); while(true){
socket = serverSocket.accept();
Thread_Client thread_Client = new Thread_Client(socket);
thread_Client.start();
System.out.println("已连接!");
list.add(thread_Client); } } catch (Exception e) {
// TODO: handle exception
System.out.println("服务端异常1");
}finally { try {
socket.close();
serverSocket.close(); } catch (IOException e2) {
// TODO: handle exception
System.out.println("服务端异常2");
} } } }

*** 然后是 处理连接后socket 的子线程***

 package socket多客户端;

 import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.lang.*;
import java.net.Socket; public class Thread_Client extends Thread{ private BufferedReader bufferedReader = null;
private PrintStream printStream = null; Socket socket; public Thread_Client(Socket socket) {
//
this.socket = socket;
} @Override
public void run() {
// TODO Auto-generated method stub
super.run(); try {
Get_Set(socket); } catch (Exception e) {
// TODO: handle exception
System.out.println("异常1");
} } public void send(String string){
if(string != null){
printStream.println(string);
printStream.flush();
}
} public void Get_Set(Socket socket){ try {
bufferedReader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
printStream = new PrintStream(socket.getOutputStream()); Boolean flag = true;
while(flag){
String string = bufferedReader.readLine();
if("".equals(string) || string == null){
flag = false;
}else{
if("end".equals(string)){
flag = false;
}else{
System.out.println("read : " + string);
//调用 主线程 广播
Server.send(string);
}
}
} } catch (IOException e) {
// TODO: handle exception
System.out.println("异常2");
}
} }

*** 最后是 客户端代码 ***

 package socket多客户端;

 import java.io.*;
import java.net.*;
import java.util.Scanner; public class Client { private static Socket socket;
private static BufferedReader bufferedReader;
private static PrintStream printStream; // 将 读服务端数据封装在 Client—read 方法里
public static void Client_read(Socket socket){
// 匿名内部类 开 一个子线程
new Thread(new Runnable() {
private BufferedReader bufferedReader_ec; @Override
public void run() {
// TODO Auto-generated method stub try {
bufferedReader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
String str = bufferedReader.readLine();
if("".equals(str) || str == null || "end".equals(str)){ }else{
System.out.println(str);
} } catch (Exception e) {
// TODO: handle exception
}
}
}).start();
} // Get_Set 方法 处理 客户端与服务端 数据的读写
static void Get_Set(Socket socket){ try {
bufferedReader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
printStream = new PrintStream(socket.getOutputStream());
Scanner keyboard = new Scanner(System.in); Boolean flag = true;
while(flag){ // 在这里调用 之前封装的 Client_read 方法
Client_read(socket); // 从 键盘 输入数据
String shuru = keyboard.nextLine();
if("".equals(shuru) || shuru == null){
flag = false; // 通过 嵌套if else 筛掉无用值
}else{
if("end".equals(shuru)){
flag = false;
}else{
printStream.println(shuru); // 发送至服务端
printStream.flush();
}
} } } catch (Exception e) {
// TODO: handle exception
} } public static void main(String[] args) { try { socket = new Socket("localhost",6789);
System.out.println("客户端已连接至服务端!");
Get_Set(socket); } catch (Exception e) {
// TODO: handle exception
System.out.println("客户端异常1");
}finally {
try {
printStream.close();
bufferedReader.close();
socket.close(); } catch (Exception e2) {
// TODO: handle exception
System.out.println("客户端异常2");
}
} } }

好了 ,下面我们来运行 看看结结果。

第一个控制台是 服务端

第二个控制台是 客户端1

第三个控制台是 客户端2

这样我们就实现了 一个简单的基于TCP/IP协议的socket多客户端通信。

笔者 还是个 编程菜鸟,有什么不好的地方,希望各位大牛可以指正。

JAVA-Socket通信笔记的更多相关文章

  1. java socket通信-传输文件图片--传输图片

    ClientTcpSend.java   client发送类 package com.yjf.test; import java.io.DataOutputStream; import java.io ...

  2. java Socket通信使用BufferedReader和BufferedWriter的注意事项

    注意事项:readLine()要求有换行标识,write()要输出换行标识,要调用flush()刷新缓冲区. 以下是取自java socket通信中的一小段代码. BufferedReader rea ...

  3. Java Socket通信读取相关信息代码

    转自:http://developer.51cto.com/art/201003/190206.htm Java Socket通信读取有不少需要我们注意的知识点.当我们在使用的时候有很多的问题摆在我们 ...

  4. Java Socket 学习笔记

    TCP协议的Socket编程 Socket:英文中的意思是插座.两个Java应用程序可以通过一个双向的网络通信连接实现数据交换,这个双向链路的一端称为一个Socket.Java中所有关于网络编程的类都 ...

  5. Java socket通信

    首先抛开语言层面,简单介绍一下socket通信过程: 1.服务器端开启监听端口,阻塞进程  等待客户端连接 2.客户端连接,这时就产生了一个socket socket就相当于一个传递消息的通道,一般都 ...

  6. Java Socket通信以及可能出现的问题解决

    Java中基于TCP协议实现网络通信的两个类:客户端的Socket和服务器端的ServerSocket. Socket通信模型如图所示: 不管Socket通信的功能有多复杂,任何socket通信过程的 ...

  7. Java Socket通信实现私聊、群聊

    前言 闲言少叙,上代码! 代码编写 server服务端 /** * 服务端 */ public class Server { private static ServerSocket server = ...

  8. Java Socket 通信实例 - 转载

    基于Tcp协议的简单Socket通信实例(JAVA)   好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些 ...

  9. Java Socket通信实例

    一.简单的客户端与服务器一对一连接: Socket通信的步骤: 1.创建ServerSocket和Socket 2.打开连接到Scket的输入/输出流 3.按照协议对Socket进行读/写操作 4.关 ...

  10. 【Java】Java Socket 通信演示样例

    用socket(套接字)实现client与服务端的通信. 这里举两个样例: 第一种是每次client发送一个数据,服务端就做一个应答. (也就是要轮流发) 另外一种是client能够连续的向服务端发数 ...

随机推荐

  1. 光环国际的PRINCE2培训时间

    一.光环国际的PRINCE2课程安排培训方式:    小班授课,50人为限;   全国网址直播课程,覆盖各个地区学员    精读原理配合独家开发大量实际案例研讨;    从商业战略角度解析PRINCE ...

  2. input 点击链接事件

  3. 学习Jammendo代码的心路历程(一)简单的淡出效果实现

    最近在看 Jammendo代码,打算将学习过程简单的记录下来,下面开始第一篇: 打开Jammendo运行之后,出弹出一个对话框,跳过对话框之后,会有一个淡出界面跳转到首页效果的实现.那么这个效果是怎么 ...

  4. POPTEST老李谈Debug和Release的区别(c#)

    POPTEST老李谈Debug和Release的区别(c#)   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣 ...

  5. Alamofire源码解读系列(十二)之时间轴(Timeline)

    本篇带来Alamofire中关于Timeline的一些思路 前言 Timeline翻译后的意思是时间轴,可以表示一个事件从开始到结束的时间节点.时间轴的概念能够应用在很多地方,比如说微博的主页就是一个 ...

  6. Swift: 使用cocoapods进行单元测试找不到bridge_header文件

    准备对项目进行单元测试,在 command + U 运行时出现了错误找不到桥接文件,如下图所示. 找了各种资料,终于解决了,如下图,可以发现search path中路径都为空,由于unit test是 ...

  7. Sublime text3 设置的中文翻译

    // While you can edit this file, it's best to put your changes in // "User/Preferences.sublime- ...

  8. 一个web应用的诞生(11)--在探首页

    就要面对本章的一个难点了,说是难点可能仅仅对于我来说,毕竟我是一个js渣,既然首页打算使用动态加载的形式,那么与后台交互的方式就要进行选择,目前比较流行的为RESTful的形式,关于RESTful的文 ...

  9. java面试题(一)

    1.面向对象的特征有哪些方面? 答:面向对象的特征主要有以下几个方面: - 抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面.抽象只关注对象有哪些属性和行为,并不关注 ...

  10. open vswitch常用操作

    以下操作都需要root权限运行,在所有命令中br0表示网桥名称,eth0为网卡名称. 添加网桥: #ovs-vsctl add-br br0 列出open vswitch中的所有网桥: #ovs-vs ...