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. Tcl与Design Compiler (七)——环境、设计规则和面积约束

    本文属于原创手打(有参考文献),如果有错,欢迎留言更正:此外,转载请标明出处 http://www.cnblogs.com/IClearner/  ,作者:IC_learner 本文的主要内容是讲解( ...

  2. sui的一些方法封装

    + function($) { "use strict"; var today = new Date(); var getDays = function(max) { var da ...

  3. SQL Server 获取本周,本月,本年等时间内记录

    datediff(week,zy_time,getdate())=0 //查询本周 datediff(month,zy_time,getdate())=0 //查询本月 本季:select * fro ...

  4. Object-C定时器,封装GCD定时器的必要性!!! (一)

    实际项目开发中经常会遇到延迟某件任务的执行,或者让某件任务周期性的执行.然后也会在某些时候需要取消掉之前延迟执行的任务. iOS中延迟操作有三种解决方案: 1.NSObject的方法:(对象方法) p ...

  5. 04 Feasibility of Learning

    机器学习是设计算法A,在假设集合H里,根据给定数据集D,选出与实际模式f最为相近的假设g(g可能与f相同,也可能不同). 那什么情况下学习是可行的?即保证g和f是相似的. 1.数据集内的表现g约等于f ...

  6. activiti 一个流程的运转步骤 以请假流程为例

    ---为了加深对activiti的理解记忆,对自己做的一个流程进行自述.加强记忆 请假实例 一.设计请假的流程图以及流程文件,完善对应数据项,比如用户信息,请假单信息 --请假单 --流程图 --流程 ...

  7. C#---------------继承和多态初步

    继承:在程序中,如果一个类A:类B,这种机制就是继承. 子类可以继承父类的所有内容(成员)吗? 解析: 1.私有成员(属性和方法) 2.构造函数 3.final修饰过的方法,子类不能进行重写 3.访问 ...

  8. 自动生成数学题型一 (框架Struts2) 题型如(a+b=c)

    1. 加减乘除 1.1 随机生成制定范围的整数 /** * 随机产生一个被限定范围的整数 * * @param num1 * 定义起始范围 num1 * @param num2 * 定义终止范围 nu ...

  9. Spring MVC执行原理

    spring的MVC执行原理 1.spring mvc将所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责对请求 进行真正的处理工作. 2.DispatcherSer ...

  10. lua metatable(元表)

    lua metatable (元表) 概述 普通 table 类型的表仅能够做一些单表操作, 无法进行一些特殊的以及两个表的操作, 比如 table1 + table2, print(table3) ...