多线程server与多client通信
鉴于ServerSocket的accept方法是阻塞的,那么只能通过多线程的方式实现多客户端连接与服务器连接
基本步骤:
1,服务端创建ServerSocket绑定端口号,循环调用accept()方法
2,客户端创建一个socket并请求和服务器端连接
3,服务器端接受客户端请求,创建socket与该客户建立连接
4,两个socket在一个单独的线程上通话
5,服务器端继续等待新的连接
//服务端代码 重复调用ServerThread
public class MultithreadingServer {
public static void main(String[] args) {
try {
ServerSocket serverSocket = new ServerSocket(6666);
System.out.println("服务端启动中....");
Socket socket = null;
int i = 0;
while(true){
socket = serverSocket.accept();//再来一个客户端就新建一个socket
ServerThread ts = new ServerThread(socket);
ts.run();
i++;
System.out.println("已有"+ i +"台客户端连接");
InetAddress address = socket.getInetAddress();//获取客户端的inetaddress对象
System.out.println("当前主机ip:" + address.getHostAddress());//获取客户端的ip
}
} catch (IOException e) {
e.printStackTrace();
}
}
public class ServerThread extends Thread{//服务器线程处理类
    Socket socket = null;
    InputStream is = null;
    BufferedReader br = null;
    OutputStream os = null;
    PrintWriter pw = null;
    public ServerThread(Socket socket) {
        this.socket = socket;
    }
    public void run(){
        try {
            is = socket.getInputStream();//获取字节流
            br = new BufferedReader(new InputStreamReader(is));
            String info = null;
            while((info = br.readLine()) != null){
                System.out.println("客户端传递的信息" + info);
            }
            socket.shutdownInput();//必须要及时关闭,因为readline这个方法是以\r\n作为界定符的,由于发送消息的那一端用的是
                                   //PrintWriter的write()方法,这个方法并没加上\r\n,所以会一直等待
            //回复客户端
            os = socket.getOutputStream();
            pw = new PrintWriter(os);
            pw.write("你好!");
            pw.flush();
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            try {
                if(pw != null){
                    pw.close();
                }
                if(br != null){
                    br.close();
                }
                if(os != null){
                    os.close();
                }
                is.close();//关闭返回的 InputStream 将关闭关联套接字。
                socket.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}
//客户端代码 举个例子 大致相同
public class Client1 { public static void main(String[] args) {
try {
Socket socket = new Socket("localhost", 6666);
System.out.println("客户端启动中....");
OutputStream os = socket.getOutputStream();
PrintWriter pw = new PrintWriter(os);
pw.write("admin");
pw.flush();
socket.shutdownOutput(); InputStream is = socket.getInputStream();
BufferedReader br = new BufferedReader(new InputStreamReader(is));
String info = null;
while((info = br.readLine()) != null){
System.out.println("服务端返回的信息" + info);
} os.close();
pw.close();
is.close();
br.close();
socket.close();
} catch (Exception e) {
e.printStackTrace();
}
} }
详细可参考:http://www.cnblogs.com/yjbjingcha/p/8268317.html
多线程server与多client通信的更多相关文章
- day26-socket(server和client通信)
		# socket是应用层与TCP/IP协议通信的中间软件抽象层,它是一组接口.它把复杂的TCP/IP协议隐藏到socket #接口的后面,让socket去组织数据,以符合指定的协议. # socket ... 
- Qt搭建多线程Server
		起因是MySQL在Android上没有驱动.也就是说,移动端想要访问远程数据库,必须通过一台(或多台)PC进行中转. 中转PC作为Server,接受来自移动端Socket访问数据库的要求,Server ... 
- key-value 多线程server的Linux C++实现
		项目需求 整体思路 网络通信 字符解析 数据存储与查询 1 存储管理 2 数据查询 多线程 待改进未实现的想法 GitHub源代码 项目需求 设计一个基于Socket或基于HTTP的server,服务 ... 
- 基于QT的多线程server
		// thread.cpp #include "thread.h" Thread::Thread(int socketDescriptor, QObject *parent) : ... 
- jmx server 和jmx client
		启动jmx server 和jmx client,通过jconsole进入jmx server 然后通过其中远程进程,进入jmx client: 发现,两者可用的tab页不同, MBean的数量类型也 ... 
- iOS开发多线程篇—线程间的通信
		iOS开发多线程篇—线程间的通信 一.简单说明 线程间通信:在1个进程中,线程往往不是孤立存在的,多个线程之间需要经常进行通信 线程间通信的体现 1个线程传递数据给另1个线程 在1个线程中执行完特定任 ... 
- Java多线程中线程间的通信
		一.使用while方式来实现线程之间的通信 package com.ietree.multithread.sync; import java.util.ArrayList; import java.u ... 
- 解决:安装SQL Server 2008 Native Client遇到错误(在Navicat premium新建sqlserver连接时 需要):An error occurred during ...HRESULT: 0x80070422(注意尾部的错误号)
		解决:安装SQL Server 2008 Native Client遇到错误(在Navicat premium新建sqlserver连接时 需要):An error occurred during . ... 
- 在socket的server端处理client端发来的数据
		一.楔子 最近做了一个需求遇到一个坑,归结成一个小问题,其实就是在socket的server端处理client端发来的数据的问题,现将这个问题总结一下,本文将数据在server端以字典的形式存储. 另 ... 
随机推荐
- CRPR/CPPR
			S CRPR clock reconvergence pessimism removal C CPPR clock path pessimism removal 剔除公共clock path上的悲 ... 
- 题解 SP8284 WEIGHT - Weighted Sum
			SP8284 WEIGHT - Weighted Sum 题意描述 给出长度为n(n<=1e6)的序列A, A中元素可能为正数,可为负数或0,.让你构造一个长度为n的序列W,给这些整数A赋权,使 ... 
- UIButton按钮的高亮状态颜色
			首先是adjustsImageWhenHighlighted属性的正确使用: UIButton的adjustsImageWhenHighlighted属性是当UIButton设置了背景图片时,并且没有 ... 
- STM32F103之USART学习记录
			1.USART的主要特性 1)名称:串行异步通信接口 2)全双工.异步通信 3)发送和接收速率最高可达4.5MBits/s 4)可编程数据长度8或9bits 5)可配置的停止位:支持1或2位停止位 6 ... 
- Presto入门介绍
			(一)背景 MapReduce不能满足大数据快速实时adhoc查询计算的性能要求,Facebook2012年开发,2013年开源 (二)是什么 基于内存的并行计算,Facebook推出的分布式SQL交 ... 
- spark streaming读取kakfka数据手动维护offset
			在spark streaming读取kafka的数据中,spark streaming提供了两个接口读取kafka中的数据,分别是KafkaUtils.createDstream,KafkaUtils ... 
- IIS反向代理配置教程(最终完整版本)
			IIS代理配置教程 插件下载:https://download.csdn.net/download/song_yan_/11996489 一.安装反向代理插件 1.rewrite插件安装 (1) 双击 ... 
- dp饭卡
			电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前,卡上的剩余金额大于或等于5元,就一定可以购买成功(即使购买后卡上余额为负),否则无法购买(即使金额足够).所以大家 ... 
- 【PAT甲级】1096 Consecutive Factors (20 分)
			题意: 输入一个int范围内的正整数,输出它最多可以被分解为多少个连续的因子并输出这些因子以*连接. trick: 测试点5包含N本身是一个素数的数据,此时应当输出1并把N输出. 测试点5包含一个2e ... 
- 转载--php 7.2 安装 mcrypt 扩展
			在 php 官网下载 mcrypt 包,php 扩展官网 # wget http://pecl.php.net/get/mcrypt-1.0.1.tgz # tar xf mcrypt-1.0.1.t ... 
