Apache Mina 學習筆記(2) - 基礎
在第一章中,我們對MINA有了一個大致的了解,在本章中,我們會對MINA中的客戶端/伺服器模型做一個細緻的分析。並且也會提供一些基於TCP,UDP的範例。
應用程式結構
服務端結構
客戶端結構
簡單的TCP伺服器
簡單的TCP客戶端
簡單的UDP伺服器
簡單的UDP框應用程式結構如下:
下面看看MINA的內部:
I/O 服務- 真正的I/O操作
I/O Handler - 在這裡完成程序的邏輯
所以,要創建一個MINA應用程序,你只需要做:
創建I/O服務- 選擇已經提供的服務(Acceptor)或自己創建的服務
創建過濾鏈- 選擇已經提供的過濾鍊或創建自己定制的過濾鏈
創建I/OHandler - 寫業務邏輯,處理各種不同的訊息以上是MINA的整體結構,
下面看看服務端的結構:
下面是客戶端模型:
其中客戶端會有一個IOConnector用來連接上服務端。而所有的處理仍然有IOHandler完成。
簡單的TCP伺服器
下面,創建一個簡單的TCP伺服器作為演示:首先你需要將一些需要的包導入到IDE或者配置你的CLASSPATH,具體方法就不詳述了,需要的包有:
MINA 2.x Core
JDK 1.5 or greater
SLF4J 1.3.0 or greater
Log4J 1.2 users: slf4j-api.jar, slf4j-log4j12., . 4j-api. jar, slf4j-log4j13.jar, and Log4J 1.3.x
java.util.logging users: slf4j-api.jar and slf4j-xk14.jar
IMPORTANT: Please make sure you matk14.jar
IMPORTANT: Please make sure you matare 是to your logging framework.
準備工作做完之後,我們開始寫程式碼
import java.net.InetSocketAddress; import org.apache.mina.core.service.IoAcceptor; import org.apache.mina.transport.socket.nio.NioSocketAcceptor; public class MinaTimeServer { private static final int PORT = 9123; public static void main( String[] args ) throws IOException { IoAcceptor acceptor = new NioSocketAcceptor(); acceptor.bind( new InetSocketAddress(PORT) ); } }
接下來,我們在上面程式碼中,加入過濾鏈的配置。
import java.io.IOException; import java.net.InetSocketAddress; import java.nio.charset.Charset; import org.apache.mina.core.service.IoAcceptor; import org.apache.mina.filter.codec.ProtocolCodecFilter; import org.apache.mina.filter.codec.textline.TextLineCodecFactory; import org.apache.mina.filter.logging.LoggingFilter; import org.apache.mina.transport.socket.nio.NioSocketAcceptor; public class MinaTimeServer { public static void main( String[] args ) { IoAcceptor acceptor = new NioSocketAcceptor(); acceptor.getFilterChain().addLast( "logger", new LoggingFilter() ); //这里会建立所有的日志信息 acceptor.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" )))); //第二个过滤器用来传递数据 acceptor.bind( new InetSocketAddress(PORT) ); } }
接下來,我們需要定義用來處理訊息的Handler,這個Handler類別必須實作IoHandler介面。在MINA中,這個Handler是程式開發的關鍵,在這個教學中,我們會繼承於IoHandlerAdapter。
import java.util.Date; import org.apache.mina.core.session.IdleStatus; import org.apache.mina.core.service.IoHandlerAdapter; import org.apache.mina.core.session.IoSession; public class TimeServerHandler extends IoHandlerAdapter { @Override public void exceptionCaught( IoSession session, Throwable cause ) throws Exception { cause.printStackTrace(); } @Override public void messageReceived( IoSession session, Object message ) throws Exception { String str = message.toString(); if( str.trim().equalsIgnoreCase("quit") ) { session.close(); return; } Date date = new Date(); session.write( date.toString() ); System.out.println("Message written..."); } @Override public void sessionIdle( IoSession session, IdleStatus status ) throws Exception { System.out.println( "IDLE " + session.getIdleCount( status )); } }
最後,完整的伺服器程式碼如下:
import java.io.IOException; import java.net.InetSocketAddress; import java.nio.charset.Charset; import org.apache.mina.core.service.IoAcceptor; import org.apache.mina.core.session.IdleStatus; import org.apache.mina.filter.codec.ProtocolCodecFilter; import org.apache.mina.filter.codec.textline.TextLineCodecFactory; import org.apache.mina.filter.logging.LoggingFilter; import org.apache.mina.transport.socket.nio.NioSocketAcceptor; public class MinaTimeServer { private static final int PORT = 9123; public static void main( String[] args ) throws IOException { IoAcceptor acceptor = new NioSocketAcceptor(); acceptor.getFilterChain().addLast( "logger", new LoggingFilter() ); acceptor.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" )))); acceptor.setHandler( new TimeServerHandler() ); //这里设置Handler acceptor.getSessionConfig().setReadBufferSize( 2048 ); //这是设置ssesion缓冲区 acceptor.getSessionConfig().setIdleTime( IdleStatus.BOTH_IDLE, 10 ); acceptor.bind( new InetSocketAddress(PORT) ); } }
運行該伺服器,然後開啟終端機輸入指令:telnet 127.0.0.1 9123 即可看到,當你輸入非「quit」 的任何字元時,伺服器都會傳回目前的時間到終端來。
簡單的TCP客戶端
import java.net.InetSocketAddress; import org.apache.mina.core.RuntimeIoException; import org.apache.mina.core.future.ConnectFuture; import org.apache.mina.core.session.IoSession; import org.apache.mina.example.sumup.codec.SumUpProtocolCodecFactory; import org.apache.mina.filter.codec.ProtocolCodecFilter; import org.apache.mina.filter.codec.serialization.ObjectSerializationCodecFactory; import org.apache.mina.filter.logging.LoggingFilter; import org.apache.mina.transport.socket.nio.NioSocketConnector; /** * (<strong>Entry Point</strong>) Starts SumUp client. * * @author <a href="http://mina.apache.org">Apache MINA Project</a> */ public class Client { private static final String HOSTNAME = "localhost"; private static final int PORT = 8080; private static final long CONNECT_TIMEOUT = 30*1000L; // 30 seconds // Set this to false to use object serialization instead of custom codec. private static final boolean USE_CUSTOM_CODEC = true; public static void main(String[] args) throws Throwable { if (args.length == 0) { System.out.println("Please specify the list of any integers"); return; } // prepare values to sum up int[] values = new int[args.length]; for (int i = 0; i < args.length; i++) { values[i] = Integer.parseInt(args[i]); } NioSocketConnector connector = new NioSocketConnector(); // Configure the service. connector.setConnectTimeoutMillis(CONNECT_TIMEOUT); if (USE_CUSTOM_CODEC) {
connector.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new SumUpProtocolCodecFactory(false))); } else { connector.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new ObjectSerializationCodecFactory())); } connector.getFilterChain().addLast("logger", new LoggingFilter()); connector.setHandler(new ClientSessionHandler(values)); IoSession session; for (;;) { try { ConnectFuture future = connector.connect(new InetSocketAddress( HOSTNAME, PORT)); future.awaitUninterruptibly(); session = future.getSession(); break; } catch (RuntimeIoException e) { System.err.println("Failed to connect."); e.printStackTrace(); Thread.sleep(5000); } } // wait until the summation is done session.getCloseFuture().awaitUninterruptibly(); connector.dispose(); } }
UDP的例子不寫了,需要的話到Apache官網去看看。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

運行 H5 項目需要以下步驟:安裝 Web 服務器、Node.js、開發工具等必要工具。搭建開發環境,創建項目文件夾、初始化項目、編寫代碼。啟動開發服務器,使用命令行運行命令。在瀏覽器中預覽項目,輸入開發服務器 URL。發布項目,優化代碼、部署項目、設置 Web 服務器配置。

導出 XML 為 PDF 有兩種方法:使用 XSLT 和使用 XML 數據綁定庫。 XSLT:創建 XSLT 樣式表,指定 PDF 格式使用 XSLT 處理器轉換 XML 數據XML 數據綁定庫:導入 XML 數據綁定庫創建 PDF 文檔對象加載 XML 數據導出 PDF 文件哪種方法更好取決於需求。 XSLT 提供靈活性,而數據綁定庫實現簡單;對於簡單轉換,數據綁定庫更好,對於復雜轉換,XSLT 更合適。

Apache錯誤可以通過查看日誌文件來診斷和解決。 1)查看error.log文件,2)使用grep命令過濾特定域名的錯誤,3)定期清理日誌文件並優化配置,4)使用監控工具實時監控和告警。通過這些步驟,可以有效地診斷和解決Apache錯誤。

生成 pom.xml 文件有以下方法:使用 Maven Archetype,提供預定義的項目模板,自動生成特定類型項目的 pom.xml 文件。使用 Maven Helper 插件,提供生成 pom.xml 文件的命令。手動創建,自定義構建項目的 pom.xml 文件。

要在服務器端設置字符編碼以解決 Bootstrap Table 亂碼,需要按以下步驟進行:檢查服務器字符編碼;編輯服務器配置文件;設置字符編碼為 UTF-8;保存並重啟服務器;驗證編碼。

XAMPP啟動MySQL失敗的原因有多種,包括端口衝突、配置文件錯誤、系統權限不足、服務依賴問題和安裝問題。排查步驟如下:1)檢查端口衝突;2)檢查配置文件;3)檢查系統權限;4)檢查服務依賴;5)重新安裝MySQL。遵循這些步驟,您可以找到並解決導致MySQL啟動失敗的問題。

Bootstrap頁面的預覽方法有:直接在瀏覽器中打開HTML文件;使用Live Server插件自動刷新瀏覽器;搭建本地服務器模擬線上環境。

如何轉換 PDF 為 XML?使用在線轉換器、桌面軟件或編程庫選擇合適的文件格式(XHTML、PDF/UA、XML)優化 PDF(OCR、刪除不必要元素、調整頁面)細化轉換設置(標記、元數據、圖像提取)質量控制(驗證 XML、手動檢查、調整)對於復雜轉換,使用專業工具
