Java Socket网络编程Server端详解
Socket通信:分为客户端和服务端的socket代码。
Java SDK提供一些相对简单的Api来完成.对于Java而言.这些Api存在与java.net 这个包里面.因此只要导入这个包就可以开始网络编程了。
网络编程的基本模型就是客户机到服务器模型。简单的说就是两个进程之间相互通讯,然后其中一个必须提供一个固定的位置,而另一个则只需要知道这个固定的位置。并去建立两者之间的联系,然后完成数据的通讯就可以了。这里提供固定位置的通常称为服务器,而建立联系的通常叫做客户端。了解这个简单的模型,就可以网络编程了。 Java对这个模型的支持有很多种Api。而这里我只想介绍有关Socket的编程接口,对于Java而言已经简化了Socket的编程接口。
创建服务器端实例有四种构造函数可以实现(Java提供了ServerSocket来对其进行支持):
首先,我们来讨论有关提供固定位置的服务方是如何建立的。事实上当你创建该类的一个实力对象并提供一个端口资源你就建立了一个固定位置可以让其他计算机来访问你。
ServerSocket server=new ServerSocket(int port); //port - 端口号;或者为 0,表示使用任何空闲端口。
这里稍微要注意的是端口的分配必须是唯一的。因为端口是为了唯一标识每台计算机唯一服务的,另外端口号是从0~65535之间的,前1024个端口已经被Tcp/Ip 作为保留端口,因此你所分配的端口只能是1024个之后的。
创建绑定到特定端口的服务器套接字。端口 0
在所有空闲端口上创建套接字。输入连接指示(对连接的请求)的最大队列长度被设置为 50
。如果队列满时收到连接指示,则拒绝该连接。
其次,创建非绑定服务器。
ServerSocket server=new ServerSocket(); //创建非绑定服务器套接字
第三,创建指定端口,最大连接数的服务器。
ServerSocket server=new ServerSocket(int port,int backlog); //port - 指定的端口;或者为 0,表示使用任何空闲端口。backlog - 队列的最大长度。
利用指定的 backlog 创建服务器套接字并将其绑定到指定的本地端口号。端口号 0
在所有空闲端口上创建套接字。输入连接指示(对连接的请求)的最大队列长度被设置为 backlog
参数。如果队列满时收到连接指示,则拒绝该连接。backlog
参数必须是大于 0 的正值。如果传递的值等于或小于 0,则假定为默认值。
第四,创建指定端口,最大连接数,指定IP的服务器。
ServerSocket server=new ServerSocket(int port,int backlog,InetAddress bindAddr);//port - 本地 TCP 端口;backlog - 侦听
//backlog;bindAddr - 要将服务器绑定到的 InetAddress
使用指定的端口、侦听 backlog 和要绑定到的本地 IP 地址创建服务器。bindAddr 参数可以在 ServerSocket 的多穴主机 (multi-homed host) 上使用,ServerSocket 仅接受对其地址之一的连接请求。如果 bindAddr 为 null,则默认接受任何/所有本地地址上的连接。端口必须在 0 到 65535 之间(包括两者)。
服务器端实例创建完成以后,就可以使用线程池来处理客户端发来的请求数据了。
ExecutorService pool = Executors.newFixedThreadPool(int poolSize); //poolSize 固定线程池大小
下面给出了一个网络服务的简单结构,这里线程池中的线程作为传入的请求。它使用了预先配置的 Executors.newFixedThreadPool(int)
工厂方法:
ServerThread.java
public class ServerThread extends Thread //此处亦可以实现Runnable接口
{
private InputStream ins = null;
private PrintWriter out = null; public ServerThread(Socket socket)
{
try
{
ins = socket.getInputStream();
out = new PrintWriter(socket.getOutputStream(), true);
socket.setSoTimeout(1000);
}
catch (IOException e)
{
e.printStackTrace();
interrupt(); // 如果发生异常 则终止线程
}
} public void run()
{
try
{
// 初始化构造函数以后会执行到这里
//从输入流中取出数据并转换成字符串格式
//处理客户端请求过来的相应数据,并做处理
String instr = "";
int temp = -1;
List<Byte> byteList = new ArrayList<Byte>();
while(true)
{
try
{
temp = ins.read();
if(temp != -1)
{
byteList.add(new Byte((byte)temp));
}
else
{
break;
}
}
catch (IOException e)
{
break;
}
} byte[] bytes = new byte[byteList.size()];
for(int i=0;i<byteList.size();i++)
{
bytes[i] = byteList.get(i);
} instr = new String(bytes);//将byte数组类型转换为字符串
System.out.println("the content of recivedMessage is:" + instr); // 这里用日志文件记录下收到的报文
out.println("Request Message has been receiver!");
out.flush();
}
catch(Exception ex)
{
ex.printStackTrace();
}
}
}
ServerSocketDemo.java
public class ServerSocketDemo extends Thread
{
private ServerSocket server = null;
private int port = 0;
private int poolsize = 0;
private int maxconn = 0; public ServerSocketDemo(int port, int poolSize,int maxconn)
{
System.out.println("port is:>>>>>>"+port);
System.out.println("poolSize is:>>>>>>"+poolSize);
System.out.println("maxconn is:>>>>>>"+maxconn); this.port = port;
this.poolsize = poolSize;
this.maxconn = maxconn;
} public void run()
{
try
{
System.out.println("the poolsize is:>>>>" + poolsize);
System.out.println("the port is:>>>>" + port);
System.out.println("the maxconn is:>>>>" + maxconn);
// 使用固定大小线程池
ExecutorService thredpool = Executors.newFixedThreadPool(poolsize);
server = new ServerSocket(port, maxconn);
server.setSoTimeout(0); // 设置不会超时
System.out.println("socket listener start!the port is:>>>>" + port
+ " and the maxConn number is:" + maxconn
+ "and the Thread Pool size is" + poolsize); while (true)
{
thredpool.execute(new ServerThread(server.accept()));
System.out.println("a ServerThread has been started!");
}
}
catch (Exception e)
{
// 这里要用日志文件记录异常
System.out.println(
"The serversocket listener exception occurred! the exception msg is>>>>"
+ e.getMessage());
}
}
}
ServerSocketTest.java
public class ServerSocketTest { /**
* @param args
*/
public static void main(String[] args)
{
// TODO Auto-generated method stub ServerSocketDemo ssd = new ServerSocketDemo(9997,50,100);
ssd.start();
} }
Java Socket网络编程Server端详解的更多相关文章
- Java Socket网络编程Client端详解
此类实现客户端套接字(也可以就叫“套接字”).套接字是两台机器之间的通信端点. Socket client = new Socket(ip,port);//创建一个流套接字并将其连接到指定 IP 地址 ...
- Java Socket 网络编程心跳设计概念
Java Socket 网络编程心跳设计概念 1.一般是用来判断对方(设备,进程或其它网元)是否正常动行,一 般采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经当掉.用于 ...
- Java Socket网络编程的经典例子(转)
事实上网络编程简单的理解就是两台计算机相互通讯数据而已,对于程序员而言,去掌握一种编程接口并使用一种编程模型相对就会显得简单的多了,Java SDK提供一些相对简单的Api来完成这些工作.Socket ...
- 循序渐进Java Socket网络编程(多客户端、信息共享、文件传输)
目录[-] 一.TCP/IP协议 二.TCP与UDP 三.Socket是什么 四.Java中的Socket 五.基本的Client/Server程序 六.多客户端连接服务器 七.信息共享 八.文件传输 ...
- Java Socket网络编程学习笔记(一)
0.前言 其实大概半年前就已经看过网络编程Socket的知识了(传统IO),但是因为长时间的不使用导致忘的一干二净,最近正好准备校招,又重新看了网络编程这一章, 是传统IO(BIO)相关的内容,故在此 ...
- java socket网络编程(多线程技术)
Client.java import java.io.*; import java.net.*; import java.util.*; public class Client { public st ...
- java socket 网络编程常见异常
1.java.net.SocketTimeoutException 这个异常比较常见,socket超时.一般有2个地方会抛出这个,一个是connect的时候,这个超时参数由connect(Socket ...
- Java Socket网络编程常见异常(转)
1.java.net.SocketTimeoutException 这个异常比较常见,socket超时.一般有2个地方会抛出这个,一个是connect的时候,这个超时参数由connect(Socket ...
- Java - TCP网络编程
Java - TCP网络编程 Server 逻辑思路: 创建ServerSocket(port),然后服务器的socket就启动了 循环中调用accept(),此方法会堵塞程序,直到发现用户请求,返回 ...
随机推荐
- CSS基础知识解析
一.基础知识 1.1 CSS组成 css 样式由选择符和声明组成,而声明又由属性和值组成,如下图所示: 选择符:又称选择器,指明网页中要应用样式规则的元素,如本例中是网页中所有的段(p)的文字将变成蓝 ...
- Asp.Net Session的三种方法及Web.Config设置
转载:http://user.gw-ec.com/login/safelog/redirectt?session=so%2f%2bSjyZURMOe54xgk%2bUhL2CgGqDjOKEbYwZS ...
- minor gc和full gc
Minor GC ,Full GC 触发条件 Minor GC触发条件:当Eden区满时,触发Minor GC. Full GC触发条件: (1)调用System.gc时,系统建议执行Full GC, ...
- Linux开发环境必备十大开发工具
Linux是一个优秀的开发环境,但是如果没有好的开发工具作为武器,这个环境给你带来的好处就会大打折扣.幸运的是,有很多好用的Linux和开源开发工具供你选择,如果你是一个新手,你可能不知道有哪些工具可 ...
- pytest文档3-pycharm运行pytest
前言 上一篇pytest文档2-用例运行规则已经介绍了如何在cmd执行pytest用例,平常我们写代码在pycharm比较多 写完用例之后,需要调试看看,是不是能正常运行,如果每次跑去cmd执行,太麻 ...
- Java垃圾回收精粹 — Part2
Java垃圾回收精粹分4个部分,本篇是第2部分.在第2部分里介绍了Hotspot中的堆结构.对象分配以及次要回收. Hotspot中的堆结构 理解不同的收集器的工作方式,是探讨Java堆结构如何支持分 ...
- BP反向传播算法的工作原理How the backpropagation algorithm works
In the last chapter we saw how neural networks can learn their weights and biases using the gradient ...
- 与多线程结合使用的消息处理类Handler、Message
1. 消息处理类——Handler 消息处理类(Handler)允许发送和处理Message或Runnable对象到其所在线程的MessageQueue中.Handerl有以下两个主要作用: 将Mes ...
- idea的一些快捷键
查找文本的出现位置就用Ctrl+F/Ctrl+Shift+F在当前窗口或全工程中查找,再配合F3/Shift+F3前后移动到下一匹配处Intellij的Ctrl+N/Ctrl+Shift+N可以打开类 ...
- Sqlmap Tamper大全
sqlmap是一个自动化的SQL注入工具,其主要功能是扫描,发现并利用给定的URL的SQL注入漏洞,目前支持的数据库是MS-SQL,,MYSQL,ORACLE和POSTGRESQL.SQLMAP采用四 ...