`
qianhao_1987
  • 浏览: 21178 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Apache Mina简单实例

阅读更多
一.简介
MINA是一个网络应用框架,也可被称之为NIO框架库、客户端/服务器框架库、网络套接字 (socket)库,可以帮助用户开发高性能和高可扩展性的网络应用程序,支持(TCP/IP、UDP/IP协议)等。

二.工作流程
MINA处于中间层,它不关心数据是如何在底层网络进行传输,只负责接受底层数据,将数据通过过滤器过滤并装换成JAVA对象,供应用程序使用,然后在应用程序对数据做过业务处理之后,将响应值过滤且转换成底层能识别的二进制数据,提供给底层传输。总之,MINA是底层数据和应用程序交互的接口。
第一步,创建服务对象(服务端、客户端)  ----IoService接口实现
第二步,数据过滤(编解码器)           ----IoFilter接口实现
第三步,业务处理                       ----IoHandler接口实现

IoFilter是MINA的精髓,可以进行日志记录,信息过滤,编解码等操作,把数据接收发送从业务层独立出来。
IoService对NIO进行了封装,提供简介接口,来创建服务对象。
IoHandler是我们最关心的部分,负责对接收/发送数据做了业务逻辑处理

三.服务端实例
private static Logger logger = Logger.getLogger(Demo1Server.class);
	private static final int PORT = 3005;

	public static void main(String[] args) {
		IoAcceptor acceptor = new NioSocketAcceptor();
		acceptor.addListener(new ServerListener());
		acceptor.getFilterChain().addLast(
				"codec",
				new ProtocolCodecFilter(new MyTextLineCodecFactory()));
		// 设置读取数据的缓冲区大小
		acceptor.getSessionConfig().setReadBufferSize(2048);
		// 读写通道10秒内无操作进入空闲状态
		acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, 10);
		// 绑定逻辑处理起器
		acceptor.setHandler(new Demo1ServerHandler());
		// 绑定端口
		try {
			acceptor.bind(new InetSocketAddress(PORT));
			logger.info("服务器启动成功。。。。端口为:" + PORT);
		} catch (IOException e) {
			logger.error("服务器启动异常。。。。", e);
			e.printStackTrace();
		}
	}


四.客户端实例
private Logger logger = Logger.getLogger(Demo2Client.class);
	private static final String HOST = "127.0.0.1";
	private static final int PORT = 3005;

	public static void main(String[] args) {
		// 创建一个非阻塞的客户端程序
		IoConnector connector = new NioSocketConnector();
		// 设置连接超时时间 单位毫秒
		connector.setConnectTimeout(30000);
		// 添加过滤器
		connector.getFilterChain().addLast(
				"codec",
				new ProtocolCodecFilter(new MyTextLineCodecFactory()));
		// 添加业务逻辑处理类
		connector.setHandler(new Demo2ClientHandler());
		// 创建连接
		IoSession session = null;
		try {
			ConnectFuture connect = connector.connect(new InetSocketAddress(
					HOST, PORT));
			// 等待连接创建完成
			connect.awaitUninterruptibly();
			// 获取session
			session = connect.getSession();
			session.write("我爱你,mina!!!!");
		} catch (Exception e) {
			System.out.println("客户端连接异常");
		}
		session.getCloseFuture().awaitUninterruptibly();
		connector.dispose();
	}


五.编解码器实例

5.1 编码器
private Logger logger = Logger.getLogger(MyTextLineCodecEncoder.class);
	//字符编码类型
	private Charset charset = Charset.forName("UTF-8");
	@Override
	public void dispose(IoSession arg0) throws Exception {
		
	}

	@Override
	public void encode(IoSession arg0, Object obj, ProtocolEncoderOutput out)
			throws Exception {
		logger.info("开始编码...........");
		IoBuffer io = IoBuffer.allocate(100).setAutoExpand(true);
		CharsetEncoder ce = charset.newEncoder();
		io.putString(obj.toString(), ce);
		io.put((byte)'\r');
		io.put((byte)'\n');
		io.flip();
		out.write(io);
	}

5.2 解码器
private Logger logger = Logger.getLogger(MyTextLineCodecDecoder.class);
	//字符编码类型
	private Charset charset = Charset.forName("UTF-8");
	//设置数据存放的IoBuffer大小
	private IoBuffer ioBuffer = IoBuffer.allocate(1024).setAutoExpand(true);
	@Override
	public void decode(IoSession session, IoBuffer in, ProtocolDecoderOutput out)
			throws Exception {
		logger.info("开始解码...........");
		while(in.hasRemaining()){
			byte by = in.get();
			//将数据存放到IoBuffer中
			ioBuffer.put(by);
			//数据解码结束标记
			if(by == '\n'){
				ioBuffer.flip();
				byte[] b = new byte[ioBuffer.limit()];
				ioBuffer.get(b);
				String msg = new String(b,charset);
				//重置ioBuffer
				ioBuffer = IoBuffer.allocate(100).setAutoExpand(true);
				out.write(msg);
			}
		}
	}
分享到:
评论

相关推荐

    apache mina实例免费下载

    MINA实例通常包含以下部分: 1. **Acceptor**:负责监听和接受新的连接请求。 2. **Session**:表示与客户端的连接,包含了与该连接相关的所有信息,如读写操作、会话属性等。 3. **Filter**:过滤器是MINA处理数据...

    Apache Mina2服务器和客户端简单实例

    在本实例中,我们将探讨如何使用Apache Mina2构建一个简单的服务器和客户端。 首先,让我们了解一下Mina2的核心概念。Mina2基于Java NIO(Non-blocking I/O)库,提供了异步I/O操作,这意味着它不会因为等待数据而...

    apache-mina例子

    这个例子是关于如何使用Apache Mina实现一个简单的服务端和客户端通信的示例。在这个案例中,`MinaTimeServer`是服务端程序,它负责监听客户端的连接请求,并发送时间信息;而`MinaClient`则是客户端程序,它连接到...

    apache mina 框架实例

    **Apache Mina框架实例:** Apache Mina框架的核心思想是基于事件驱动和非阻塞I/O,这使得它在处理大量并发连接时表现出色。在Mina中,开发者可以创建一个服务端来监听特定端口,并接收客户端的连接请求。一旦连接...

    Apache Mina帮助文档

    "Apache Mina chm pdf教程和帮助文档"提供了详尽的API参考和实例,涵盖了从基本概念到高级特性的各个方面,有助于开发者快速掌握Mina的使用方法。 **7. 社区支持** Apache Mina作为一个活跃的开源项目,拥有强大的...

    apache mina 学习笔记三(子项目FtpServer)

    Apache MINA(Multipurpose Infrastructure for Network Applications)是一个Java框架,用于构建高性能、高可用性的网络应用程序。MINA 提供了一种简单而强大的API,开发者可以使用它来处理TCP/IP和UDP/IP协议,如...

    apache mina socket实例

    mina简单示例,Apache Mina Server 是一个网络通信应用框架,也就是说,它主要是对基于TCP/IP、UDP/IP协议栈的通信框架(当然,也可以提供JAVA 对象的序列化服务、虚拟机管道通信服务等),Mina 可以帮助我们快速...

    Apache MINA 线程模型配置

    ### Apache MINA线程模型配置详解 #### 一、线程模型配置介绍 Apache MINA 是一个用于构建网络应用程序的高性能、高可靠性的框架。它提供了丰富的功能来简化网络编程,包括TCP/IP 和 UDP/IP 协议的支持。线程模型...

    Mina开发实例(服务端、客户端)DEMO

    总结一下,这个"Mina开发实例"涵盖了如何使用Apache Mina创建服务端和客户端,通过Maven构建项目,并实现长连接通信。通过学习和实践这个DEMO,开发者可以掌握Mina的基本用法,为构建高性能、高并发的网络应用打下...

    Apache mina源代码框架解析

    在这个文档中,我们将简要分析Mina 2.0框架的源代码,并通过一个简单的时钟服务器示例来了解其工作原理。 首先,我们来看`MinaTimeServer`类。这个类是Mina服务器的主入口点,它创建了一个`NioSocketAcceptor`实例...

    基于Apache Mina实现的TCP长连接和短连接实例

    在这个实例中,我们将深入探讨如何利用Apache Mina实现TCP的长连接和短连接。 首先,TCP(传输控制协议)是互联网上广泛使用的面向连接的协议,它保证了数据的可靠传输。TCP连接分为两种类型:长连接和短连接。 1....

    apache mina

    Mina 2.0.16 简介 代码实例 Mina 是Apache开发的一个开源的网络通信框架,基于java NIO实现。 建立server与client之间的会话连接,对会话消息进行过滤; 非阻塞消息会话机制; 通过自定义的通信协议进行编解码消息。

    Apache MINA java UDP例子|byte数组

    最近做rfid读写,C#和java都用udp不用厂家的动态库,udp自己写也简单,但是试了一下Apache mina ,接收的不是string,二十byte[] 数组,简单实现了UDP,网上也有例子,但是不是我要的。可用。

    深入理解Apache Mina (6)---- Java Nio ByteBuffer与Mina ByteBuffer的区别

    2. 基于池化的管理:Mina通过缓冲区池来复用ByteBuffer实例,减少频繁的创建和销毁操作,提高性能。 3. 多种类型支持:Mina提供多种类型的ByteBuffer,如HeapByteBuffer、DirectByteBuffer和复合缓冲区,可以根据...

    ApacheMina典型例子分析参考.pdf

    Apache Mina是一个强大的Java框架,专门用于构建高性能的异步并发网络通信应用。它支持多种通信协议,如TCP/IP、UDP/IP、串口通讯、VM间的管道通讯,以及SSL/TLS和JXM集成。此外,Mina也能够与IoC容器(如Spring和...

    Apache_Mina.zip_apache_mina

    Apache Mina的核心理念是提供一个简单、一致的API来处理各种网络协议,无论是在TCP/IP还是UDP上。它通过使用Java NIO(Non-blocking I/O)库,实现了高效的I/O处理,允许开发者编写非阻塞式的网络应用,这在高并发...

    Apache Mina网络通信应用框架实例

    Apache Mina Server 是一个网络通信应用框架 基于 TCP/IP、UDP/IP协议栈的通信框架 支持串口和虚拟机内部的管道等传输方式 Mina 可以帮助我们快速开发高性能、高扩展性的网络通信应用 Mina 提供了事件驱动、异步操作...

Global site tag (gtag.js) - Google Analytics