问题描述
各位大侠....小弟想用Mina做一个文件传输的东东....但有关于这方面的资料太少了..希望有这方面资料的朋友发给实例到我的邮箱1563300160@qq.com谢谢啦...或者给个意见或提议也行~
解决方案
解决方案二:
Mina又是什么?
解决方案三:
英文稍微好的话,去apache主页上看看,源码,jar包,示例代码,doc一应俱全mina是搞socket短连接/长连接的一些东西,简短点可以这么说。。。
解决方案四:
没有人有吗???我想要个实例...或者知道怎么实现的人说一下思路
解决方案五:
没有接触过Mina,帮楼主顶一下吧。
解决方案六:
该回复于2010-12-03 11:53:07被版主删除
解决方案七:
我整理的资料希望对你有帮助:1。所需要的包:slf4j-api.jar、slf4j-jdk14.jar、MINA-core-2.0.0-M1.jar。2。MINA框架简介MINA(MultipurposeInfrastructureforNetworkApplications)是用于开发高性能和高可用性的网络应用程序的基础框架。通过使用MINA框架可以可以省下处理底层I/O和线程并发等复杂工作,开发人员能够把更多的精力投入到业务设计和开发当中。MINA框架的应用比较广泛,应用的开源项目有ApacheDirectory、AsyncWeb、ApacheQpid、QuickFIX/J、Openfire、SubEthaSTMP、red5等。MINA框架当前稳定版本是1.1.6,最新的2.0版本目前已经发布了M1版本。MINA框架的特点有:基于javaNIO类库开发;采用非阻塞方式的异步传输;事件驱动;支持批量数据传输;支持TCP、UDP协议;控制反转的设计模式(支持Spring);采用优雅的松耦合架构;可灵活的加载过滤器机制;单元测试更容易实现;可自定义线程的数量,以提高运行于多处理器上的性能;采用回调的方式完成调用,线程的使用更容易。2.MINA框架的常用类类NioSocketAcceptor用于创建服务端监听;类NioSocketConnector用于创建客户端连接;类IoSession用来保存会话属性和发送消息;类IoHandlerAdapter用于定义业务逻辑,常用的方法有:方法定义sessionCreated()当会话创建时被触发sessionOpened()当会话开始时被触发sessionClosed()当会话关闭时被触发sessionIdle()当会话空闲时被触发exceptionCaught()当接口中其他方法抛出异常未被捕获时触发此方法messageRecieved()当接收到消息后被触发messageSent()当发送消息后被触发3.服务端应用开发示例下面将以MINA2.0M1版本为基础,通过一个范例来演示一下如何使用MINA框架进行开发。开发环境为jdk6.0,开发工具NetBeans6.0,所需jar包slf4j-api.jar、slf4j-jdk14.jar、MINA-core-2.0.0-M1.jar。首先定义一个业务逻辑处理器TimeServerHandler,继承自IoHandlerAdapter,实现的功能有:当客户端创建会话时会显示客户端设备的IP和端口;当客户端输入quit时结束会话;客户端输入其它内容时则向客户端发送当前时间。代码如下:publicclassTimeServerHandlerextendsIoHandlerAdapter{@OverridepublicvoidsessionCreated(IoSessionsession){//显示客户端的ip和端口System.out.println(session.getRemoteAddress().toString());}@OverridepublicvoidmessageReceived(IoSessionsession,Objectmessage)throwsException{Stringstr=message.toString();if(str.trim().equalsIgnoreCase("quit")){session.close();//结束会话return;}Datedate=newDate();session.write(date.toString());//返回当前时间的字符串System.out.println("Messagewritten...");}}再定义一个类MinaTimeServer用来启动服务端:publicclassMinaTimeServer{privatestaticfinalintPORT=9123;//定义监听端口publicstaticvoidmain(String[]args)throwsIOException{IoAcceptoracceptor=newNioSocketAcceptor();acceptor.getFilterChain().addLast("logger",newLoggingFilter());acceptor.getFilterChain().addLast("codec",newProtocolCodecFilter(newTextLineCodecFactory(Charset.forName("UTF-8"))));//指定编码过滤器acceptor.setHandler(newTimeServerHandler());//指定业务逻辑处理器acceptor.setDefaultLocalAddress(newInetSocketAddress(PORT));//设置端口号acceptor.bind();//启动监听}}4.测试首先运行MinaTimeServer,启动服务端,接着在命令行运行“telnet127.0.0.19123”,来登录,这时会看到服务端输出如下:2008-2-2116:15:29org.apache.MINA.filter.logging.LogLevel$4log/10.64.2.137:4140?IP和端口号信息:CREATED2008-2-2116:15:29org.apache.MINA.filter.logging.LogLevel$4log信息:OPENED在客户端输入回车,在客户端可以看到服务端返回当前的时间:ThuFeb2116:20:14CST2008服务端输出:2008-2-2116:20:14org.apache.MINA.filter.logging.LogLevel$4log信息:RECEIVED:HeapBuffer[pos=0lim=2cap=2048:0D0A]?接收收到回车符Messagewritten...2008-2-2116:20:14org.apache.MINA.filter.logging.LogLevel$4log信息:SENT:HeapBuffer[pos=0lim=29cap=30:546875204665622032312031363A3230...]2008-2-2116:20:14org.apache.MINA.filter.logging.LogLevel$4log信息:SENT:HeapBuffer[pos=0lim=0cap=0:empty]5.客户端开发示例首先定义类TimeClientHandler来处理消息接收事件:classTimeClientHandlerextendsIoHandlerAdapter{publicTimeClientHandler(){}@OverridepublicvoidmessageReceived(IoSessionsession,Objectmessage)throwsException{System.out.println(message);//显示接收到的消息}}接着定义MinaTimeClient类用于连接服务端,并向服务端发送消息:publicclassMinaTimeClient{publicstaticvoidmain(String[]args){//创建客户端连接器.NioSocketConnectorconnector=newNioSocketConnector();connector.getFilterChain().addLast("logger",newLoggingFilter());connector.getFilterChain().addLast("codec",newProtocolCodecFilter(newTextLineCodecFactory(Charset.forName("UTF-8"))));//设置编码过滤器connector.setConnectTimeout(30);connector.setHandler(newTimeClientHandler());//设置事件处理器ConnectFuturecf=connector.connect(newInetSocketAddress("127.0.0.1",9123));//建立连接cf.awaitUninterruptibly();//等待连接创建完成cf.getSession().write("hello");//发送消息cf.getSession().write("quit");//发送消息cf.getSession().getCloseFuture().awaitUninterruptibly();//等待连接断开connector.dispose();}}5.mina的深层理解I/O服务:I/O服务用来执行实际的I/O操作。ApacheMINA已经提供了一系列支持不同协议的I/O服务,如TCP/IP、UDP/IP、串口和虚拟机内部的管道等。开发人员也可以实现自己的I/O服务。I/O过滤器:I/O服务能够传输的是字节流,而上层应用需要的是特定的对象与数据结构。I/O过滤器用来完成这两者之间的转换。I/O过滤器的另外一个重要作用是对输入输出的数据进行处理,满足横切的需求。多个I/O过滤器串联起来,形成I/O过滤器链。I/O处理器:I/O处理器用来执行具体的业务逻辑。对接收到的消息执行特定的处理。创建一个完整的基于ApacheMINA的网络应用,需要分别构建这三个层次。ApacheMINA已经为I/O服务和I/O过滤器提供了不少的实现,因此这两个层次在大多数情况下可以使用已有的实现。I/O处理器由于是与具体的业务相关的,一般来说都是需要自己来实现的。事件驱动的APIApacheMINA提供的是事件驱动的API。它把与网络相关的各种活动抽象成事件。网络应用只需要对其感兴趣的事件进行处理即可。事件驱动的API使得基于ApacheMINA开发网络应用变得比较简单。应用不需要考虑与底层传输相关的具体细节,而只需要处理抽象的I/O事件。比如在实现一个服务端应用的时候,如果有新的连接进来,I/O服务会产生sessionOpened这样一个事件。如果该应用需要在有连接打开的时候,执行某些特定的操作,只需要在I/O处理器中此事件处理方法sessionOpened中添加相应的代码即可。在介绍ApacheMINA中的基本概念的细节之前,首先通过一个简单的应用来熟悉上面提到的三个层次的具体职责。
解决方案八:
学习下。。
解决方案九:
JAVA开发两年第一次听说Mina