Android 基於Netty的訊息推送方案之字串的接收和傳送(三)
Android 基於Netty的訊息推送方案之字串的接收和傳送(三)
在上一篇文章中《Android 基於Netty的訊息推送方案之概念和工作原理(二)》 ,我們介紹過一些關於Netty的概念和工作原理的內容,今天我們先來介紹一個叫做ChannelBuffer的東東。
ChannelBuffer
Netty中的訊息傳遞,都必須以位元組的形式,以ChannelBuffer為載體傳遞。簡單的說,就是你想直接寫個字串過去,對不起,拋異常。雖然,Netty定義的writer的介面引數是Object的,這可能也是會給新上手的朋友容易造成誤會的地方。Netty原始碼中,是這樣判斷的。
[java] view plaincopy
- SendBuffer acquire(Object message) {
- if (message instanceof ChannelBuffer) {
- return acquire((ChannelBuffer) message);
- } else if (message instanceof FileRegion) {
- return acquire((FileRegion) message);
- }
- throw new IllegalArgumentException(
- "unsupported message type: " + message.getClass());
- }
接下來我們寫一個Demo來學習它。
服務端程式碼如下
[java] view plaincopy
- public class MessageServer {
- public static void main(String args[]){
- //服務啟動器
- ServerBootstrap bootstrap = new ServerBootstrap(new NioServerSocketChannelFactory(Executors.newCachedThreadPool(),Executors.newCachedThreadPool()));
- //設定一個處理客戶端訊息和各種訊息事件的類(Handler)
- bootstrap.setPipelineFactory(new ChannelPipelineFactory(){
- @Override
- public ChannelPipeline getPipeline() throws Exception {
- return Channels.pipeline(new BusinessHandler());
- }
- });
- //開放8000埠供客戶端連線
- bootstrap.bind(new InetSocketAddress(8000));
- }
- private static class BusinessHandler extends SimpleChannelHandler{
- // 服務端收到客戶端傳送過來的訊息時,觸發此方法
- @Override
- public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) throws Exception {
- ChannelBuffer buffer = (ChannelBuffer)e.getMessage();
- System.out.println("Receive:"+buffer.toString(Charset.defaultCharset()));
- String msg = buffer.toString(Charset.defaultCharset()) + "has been processed!";
- ChannelBuffer buffer2 = ChannelBuffers.buffer(msg.length());
- buffer2.writeBytes(msg.getBytes());
- e.getChannel().write(buffer2);
- }
- }
- }
客戶端程式碼如下
[java] view plaincopy
- public class MessageClient {
- public static void main(String args[]) {
- ClientBootstrap bootstrap = new ClientBootstrap(new NioClientSocketChannelFactory(Executors.newCachedThreadPool(), Executors.newCachedThreadPool()));
- bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
- @Override
- public ChannelPipeline getPipeline() throws Exception {
- return Channels.pipeline(new MessageClientHandler());
- }
- });
- bootstrap.connect(new InetSocketAddress("127.0.0.1", 8000));
- }
- private static class MessageClientHandler extends SimpleChannelHandler {
- /**
- * 當繫結到服務端的時候觸發,給服務端發訊息。
- */
- @Override
- public void channelConnected(ChannelHandlerContext ctx, ChannelStateEvent e) {
- // 將字串,構造成ChannelBuffer,傳遞給服務端
- String msg = "Hello, I'm client.";
- ChannelBuffer buffer = ChannelBuffers.buffer(msg.length());
- buffer.writeBytes(msg.getBytes());
- e.getChannel().write(buffer);
- }
- }
- }
先啟動服務端,再啟動客戶端,可以看到服務端列印如下字串
[java] view plaincopy
- Receive:Hello, I'm client.
如果你感興趣,請繼續閱讀《Android 基於Netty的訊息推送方案之物件的傳遞(四)》
相關文章
- Android 基於Netty的訊息推送方案之概念和工作原理(二)AndroidNetty
- Android 基於Netty的訊息推送方案之Hello World(一)AndroidNetty
- 排查MQ訊息傳送和接收MQ
- 網路核心之TCP是如何傳送和接收訊息的TCP
- Android之訊息推送原理Android
- 一個基於 swoole 的非同步 mqtt 客戶端庫,可用於接收或者傳送 mqtt 協議的訊息非同步MQQT客戶端協議
- Go的Channel傳送和接收Go
- Rocket MQ 的三種訊息傳送(同步、非同步、單向)和訊息訂閱MQ非同步
- 基於 EasyWechat 和 Laravel notification 傳送微信小程式模板訊息Laravel微信小程式
- PHP基於Redis訊息佇列實現的訊息推送的方法PHPRedis佇列
- Android Handler 訊息傳送效能優化Android優化
- Android 訊息推送:第三方訊息推送平臺 詳細解析Android
- Rocket MQ傳送訊息的三種方式初析MQ
- 用程式碼理解 ObjC 中的傳送訊息和訊息轉發OBJ
- RocketMQ中Producer訊息的傳送MQ
- 傳送不同型別的訊息型別
- netty系列之:基於流的資料傳輸Netty
- RocketMQ(6)---傳送普通訊息(三種方式)MQ
- 0229-UDP 傳送和接收UDP
- 0230-TCP 傳送和接收TCP
- 0x2_訊息的傳送
- 傳送kafka訊息的shell指令碼Kafka指令碼
- 基於 Hyperf 實現 RabbitMQ + WebSocket 訊息推送MQWeb
- RocketMQ(八):訊息傳送MQ
- 【RocketMQ】MQ訊息傳送MQ
- 訊息中介軟體—RocketMQ訊息傳送MQ
- Laravel 實現 Kafka 訊息推送與接收處理LaravelKafka
- 釘釘推送機器人訊息傳送 Laravel 擴充套件包機器人Laravel套件
- 實時訊息推送方案-SSE
- uni-app訊息推送方案APP
- 基於workerman實現的web訊息推送站內信功能Web
- netty系列之:netty對http2訊息的封裝NettyHTTP封裝
- Knative 實戰:基於 Kafka 實現訊息推送Kafka
- 淺談iOS和Android後臺實時訊息推送的原理和區別iOSAndroid
- TNW-傳送模板訊息TNW
- RocketMQ(九):訊息傳送(續)MQ
- 鴻蒙傳送訊息通知鴻蒙
- 6-RocketMQ傳送訊息MQ