Java socket通信已经被封装好了主要使用两个类ServerSocket 和Socket (2)
来源:互联网 发布:华为 云计算部门 编辑:程序博客网 时间:2024/06/10 22:21
Java socket通信已经被封装好了主要使用两个类ServerSocket 和Socket
(2)
上次做了一个Java socket一对一通信的例子这次来写一个一对多的通信,这里我们使用Java的多线程来实现
首先来看一下服务类
[java] view plain copy
/** * */ package com.dnion.socket; import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; /** *************************************************************** * 项目名称:JavaThread * 程序名称:MultiJabberServer * 日期:2012-8-23 下午02:38:20 * 作者: * 模块: * 描述: * 备注: * ------------------------------------------------------------ * 修改历史 * 序号 日期 修改人 修改原因 * * 修改备注: * @version *************************************************************** */ public class MultiJabberServer { /** * 方法名:main * 描述: * 作者: * 日期:2012-8-23 下午02:38:20 * @param @param args * @return void */ public static void main(String[] args) { ServerSocket s = null; Socket socket = null; try { s = new ServerSocket(8080); //等待新请求、否则一直阻塞 while(true){ socket = s.accept(); System.out.println("socket:"+socket); new ServeOneJabbr(socket); } } catch (Exception e) { try { socket.close(); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } }finally{ try { s.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }
接着我们要写一个服务端响应请求的类也就是一个socket
[java] view plain copy
/** * */ package com.dnion.socket; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStreamWriter; import java.io.PrintWriter; import java.net.Socket; /** *************************************************************** * 项目名称:JavaThread * 程序名称:ServeOneJabbr * 日期:2012-8-23 下午02:34:13 * 作者: * 模块: * 描述: * 备注: * ------------------------------------------------------------ * 修改历史 * 序号 日期 修改人 修改原因 * * 修改备注: * @version *************************************************************** */ public class ServeOneJabbr extends Thread{ private Socket socket = null; private BufferedReader br = null; private PrintWriter pw = null; public ServeOneJabbr(Socket s){ socket = s; try { br = new BufferedReader(new InputStreamReader(socket.getInputStream())); pw = new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())),true); start(); } catch (Exception e) { e.printStackTrace(); } } @Override public void run() { while(true){ String str; try { str = br.readLine(); if(str.equals("END")){ br.close(); pw.close(); socket.close(); break; } System.out.println("Client Socket Message:"+str); pw.println("Message Received"); pw.flush(); } catch (Exception e) { try { br.close(); pw.close(); socket.close(); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } } } } }
接下来利用我们上一次的客户端socket
[java] view plain copy
/** * */ package com.dnion.socket; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStreamWriter; import java.io.PrintWriter; import java.net.Socket; /** *************************************************************** * 项目名称:JavaThread 程序名称:JabberClient 日期:2012-8-23 下午01:47:12 * 作者: * 模块: * 描述: * 备注: * ------------------------------------------------------------ * 修改历史 * 序号 * 日期 * 修改人 * 修改原因 * 修改备注: * * @version *************************************************************** */ public class JabberClient { /** * 方法名:main 描述: 作者:白鹏飞 日期:2012-8-23 下午01:47:12 * * @param @param args * @return void */ public static void main(String[] args) { Socket socket = null; BufferedReader br = null; PrintWriter pw = null; try { //客户端socket指定服务器的地址和端口号 socket = new Socket("127.0.0.1", JabberServer.PORT); System.out.println("Socket=" + socket); //同服务器原理一样 br = new BufferedReader(new InputStreamReader( socket.getInputStream())); pw = new PrintWriter(new BufferedWriter(new OutputStreamWriter( socket.getOutputStream()))); for (int i = 0; i < 10; i++) { pw.println("howdy " + i); pw.flush(); String str = br.readLine(); System.out.println(str); } pw.println("END"); pw.flush(); } catch (Exception e) { e.printStackTrace(); } finally { try { System.out.println("close......"); br.close(); pw.close(); socket.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }
这样一个简单地多客户端响应socket就成了
每次有一个请求发送过来服务端都会新建一个线程来单独服务。
0 0
- Java socket通信已经被封装好了主要使用两个类ServerSocket 和Socket (2)
- Java socket通信已经被封装好了主要使用两个类ServerSocket 和Socket
- Java Socket和ServerSocket
- [Java]Socket和ServerSocket
- Socket和ServerSocket通信例子
- java socket通信总结笔记2——Socket和ServerSocket
- java网络编程:Socket和ServerSocket类
- Java网络编程(ServerSocket和Socket)
- Socket和ServerSocket的使用
- [Java]Socket和ServerSocket学习
- java38.Socket通信------使用ServerSocket建立聊天服务器---2
- 基于Socket和ServerSocket实现通信
- Java Tcp(Socket、ServerSocket)
- java socket BIO (ServerSocket,Socket,多线程)
- Java ServerSocket Socket
- 使用Socket和ServerSocket上传文件
- 安卓Socket和ServerSocket的使用
- android ServerSocket 和 Socket使用简单讲解
- Linux有多个php版本的时候指定php版本设置环境变量
- MapReduce入门示例-WordCount
- 文章标题
- boost的asio接收单路大数据量udp包的方法
- Word中A3纸的表格转化成A4纸的表格打印
- Java socket通信已经被封装好了主要使用两个类ServerSocket 和Socket (2)
- 项目中加入百度联盟广告。
- Deep Learning方向的paper
- iOS 10.3可能的重大修改: keychain在app删除重装后不再保持一致性
- docker容器查看进程号码
- 此数据库没有有效所有者,因此无法安装数据库关系图支持对象。
- lex yacc学习
- javascript 2
- 在对UITableView添加长按事件的时候,有的列表不响应长按