日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Netty-案例 WebSocket与netty实现长连接案例(代码注释详解)

發(fā)布時(shí)間:2024/4/15 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Netty-案例 WebSocket与netty实现长连接案例(代码注释详解) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Netty

記錄學(xué)習(xí),開心學(xué)習(xí),來(lái)源尚硅谷韓順平netty視頻

1 NettyServer

package com.fs.netty.simple;import io.netty.bootstrap.ServerBootstrap; import io.netty.channel.*; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.nio.NioServerSocketChannel;public class NettyServer {public static void main(String[] args) throws InterruptedException {//創(chuàng)建boosGroup 和 workerGroup//創(chuàng)建兩個(gè)線程組,bossGroup workerGroup//bossGroup只是處理鏈接請(qǐng)求//workerGroup 真正的與客戶端業(yè)務(wù)處理,會(huì)交給workerGroup完成,自己不做處理//兩個(gè)都是無(wú)線循環(huán)EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();//處理整個(gè)服務(wù)的異常try {//創(chuàng)建服務(wù)器端啟動(dòng)的配置參數(shù)對(duì)象ServerBootstrap bootstrap = new ServerBootstrap();//使用鏈?zhǔn)骄幊虂?lái)進(jìn)行參數(shù)設(shè)置bootstrap.group(bossGroup, workerGroup)//設(shè)置兩個(gè)線程組.channel(NioServerSocketChannel.class)//設(shè)置服務(wù)器的通道實(shí)現(xiàn)使用NioServerSocketChannel.option(ChannelOption.SO_BACKLOG,128)//設(shè)置線程隊(duì)列等待的個(gè)數(shù).childOption(ChannelOption.SO_KEEPALIVE,true)//設(shè)置鏈接保持活動(dòng)鏈接狀態(tài).childHandler(new ChannelInitializer<SocketChannel>() {//創(chuàng)建一個(gè)通道初始化對(duì)象,使用匿名內(nèi)部類方式//給pipeline設(shè)置處理器@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {//addLast給ChannelPipeline添加我們自定義的handlersocketChannel.pipeline().addLast(new NettyServerHandler());}});//給我們的workerGroup的EventLoop對(duì)應(yīng)的管道設(shè)置處理器//給我們服務(wù)端綁定端口并且同步處理,生成一個(gè)ChannelFuture,啟動(dòng)服務(wù)器ChannelFuture channelFuture = bootstrap.bind(6668).sync();System.out.println("----服務(wù)器is ready");//對(duì)關(guān)閉通道進(jìn)行監(jiān)聽channelFuture.channel().closeFuture().sync();}finally {//出現(xiàn)異常,優(yōu)雅的關(guān)閉bossGroup.shutdownGracefully();workerGroup.shutdownGracefully();}} }

1.1 NettyServerHandler

package com.fs.netty.simple;import io.netty.buffer.ByteBuf; import io.netty.buffer.Unpooled; import io.netty.channel.Channel; import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelInboundHandlerAdapter; import io.netty.channel.ChannelPipeline; import io.netty.util.CharsetUtil;//繼承ChannelInboundHandlerAdapter/*** 我們自定義一個(gè)Handler,需要繼承某個(gè)handler適配器(ChannelInboundHandlerAdapter)* 這時(shí)我們自定義的handler才能稱之為一個(gè)handler* 因?yàn)槲覀円袷啬承┮?guī)范,有些方法需要從寫的*/ public class NettyServerHandler extends ChannelInboundHandlerAdapter {/*** 讀取數(shù)據(jù)事件(這里我們可以讀取客戶端發(fā)送的消息)* @param ctx 上下文對(duì)象,包含了管道pipeline(做業(yè)務(wù)邏輯) 通道channel(做數(shù)據(jù)讀寫) 地址等* @param msg 客戶端發(fā)送的數(shù)據(jù),默認(rèn)Object*/@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {System.out.println("服務(wù)器讀取線程:"+Thread.currentThread().getName());System.out.println("server ctx :"+ctx);//將msg轉(zhuǎn)成byteBuf(是netty提供的,不是NIO的byteBuffer,ByteBuf性能更高)ByteBuf byteBuf = (ByteBuf) msg;System.out.println("看看channel與pipeline的關(guān)系");Channel channel = ctx.channel();ChannelPipeline pipeline = ctx.pipeline();//pipeline 本質(zhì)是一個(gè)雙向鏈表,本質(zhì)是出站入站//Debug得知,channle與pipeline是相互包含的關(guān)系,你中有我,我中有你System.out.println("客戶端發(fā)送消息是:"+byteBuf.toString(CharsetUtil.UTF_8));System.out.println("客戶端地址:"+ channel.remoteAddress());}/*** 數(shù)據(jù)讀取完畢* @param ctx 上下文對(duì)象*/@Overridepublic void channelReadComplete(ChannelHandlerContext ctx) throws Exception {//將數(shù)據(jù)寫入到緩存,并刷新//一般對(duì)發(fā)送的數(shù)據(jù)進(jìn)行編碼ctx.writeAndFlush(Unpooled.copiedBuffer("hello,客戶端~xixixi",CharsetUtil.UTF_8));}/*** 發(fā)生異常處理,一般需要關(guān)閉通道* @param ctx 上下文對(duì)象*/@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {ctx.close();} }

2 NettyClient

package com.fs.netty.simple;import io.netty.bootstrap.Bootstrap; import io.netty.channel.ChannelFuture; import io.netty.channel.ChannelInitializer; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.nio.NioSocketChannel;public class NettyClient {public static void main(String[] args) throws InterruptedException {//客戶端只需要一個(gè)事件循環(huán)組NioEventLoopGroup eventLoopGroup = new NioEventLoopGroup();try {//創(chuàng)建客戶端啟動(dòng)對(duì)象//注意客戶端使用的不是 ServerBootStrap 而是BootStarpBootstrap bootstrap = new Bootstrap();//設(shè)置相關(guān)參數(shù)bootstrap.group(eventLoopGroup)//設(shè)置線程組.channel(NioSocketChannel.class)//設(shè)置客戶端通道的實(shí)現(xiàn)類(反射處理).handler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {socketChannel.pipeline().addLast(new NettyClientHandler());//加入自定義客戶端處理器}});System.out.println("客戶端 is --- ok");//啟動(dòng)客戶端去鏈接服務(wù)的//關(guān)于ChannelFuture 要分析,涉及到netty的異步模型ChannelFuture channelFuture = bootstrap.connect("127.0.0.1", 6668).sync();//給關(guān)閉通道進(jìn)行監(jiān)聽channelFuture.channel().closeFuture().sync();}finally {//出現(xiàn)異常,優(yōu)雅的關(guān)閉eventLoopGroup.shutdownGracefully();}} }

2.2 NettyClientHandler

package com.fs.netty.simple;import io.netty.buffer.ByteBuf; import io.netty.buffer.Unpooled; import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelInboundHandlerAdapter; import io.netty.util.CharsetUtil;/* 客戶端處理器*/ public class NettyClientHandler extends ChannelInboundHandlerAdapter {/*** 當(dāng)通道就緒就會(huì)觸發(fā)* @param ctx 上下文對(duì)象,包含了管道pipeline(做業(yè)務(wù)邏輯) 通道channel(做數(shù)據(jù)讀寫) 地址等*/@Overridepublic void channelActive(ChannelHandlerContext ctx) throws Exception {System.out.println("client :"+ ctx);ctx.writeAndFlush(Unpooled.copiedBuffer("Hello,Server:hahaha", CharsetUtil.UTF_8));}/*** 當(dāng)通道有讀取事件的時(shí)候,會(huì)觸發(fā)* @param ctx 上下文對(duì)象* @param msg 消息*/@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {ByteBuf byteBuf = (ByteBuf)msg;System.out.println("服務(wù)器回復(fù)的消息:"+byteBuf.toString(CharsetUtil.UTF_8));System.out.println("服務(wù)器地址:"+ctx.channel().remoteAddress());}/*** 異常觸發(fā)* @param ctx 上下文對(duì)象* @param cause 異常對(duì)象*/@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {cause.printStackTrace();ctx.close();} }

3 用戶自定義普通任務(wù)隊(duì)列 異步執(zhí)行(將任務(wù)提交到taskQueue)

在channelRead方法中將消息存放在taskQueue隊(duì)列中
(NettyServerHandler extends ChannelInboundHandlerAdapter 重寫的channelRead()方法)

/*** 讀取數(shù)據(jù)事件(這里我們可以讀取客戶端發(fā)送的消息)* @param ctx 上下文對(duì)象,包含了管道pipeline(做業(yè)務(wù)邏輯) 通道channel(做數(shù)據(jù)讀寫) 地址等* @param msg 客戶端發(fā)送的數(shù)據(jù),默認(rèn)Object*/@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {//這里有一個(gè)非常耗時(shí)的時(shí)間業(yè)務(wù),---》異步執(zhí)行,提交到channel、對(duì)應(yīng)的//NIOEventLoop 的 TaskQueue/*Thread.sleep(10*1000);ctx.writeAndFlush(Unpooled.copiedBuffer("hello-客戶端-讀完",CharsetUtil.UTF_8));System.out.println("繼續(xù)執(zhí)行");這個(gè)是阻塞的,那這樣netty還是阻塞的*///解決方案一,用戶程序自定義的普通程序ctx.channel().eventLoop().execute(new Runnable() {@Overridepublic void run() {try {Thread.sleep(10*1000);} catch (InterruptedException e) {e.printStackTrace();}ctx.writeAndFlush(Unpooled.copiedBuffer("hello-客戶端-讀完",CharsetUtil.UTF_8));}});//下面這個(gè)線程是上面10秒后20秒在執(zhí)行,所以taskQueue是阻塞隊(duì)列。在同一個(gè)線程下ctx.channel().eventLoop().execute(new Runnable() {@Overridepublic void run() {try {Thread.sleep(20*1000);} catch (InterruptedException e) {e.printStackTrace();}ctx.writeAndFlush(Unpooled.copiedBuffer("hello-客戶端-讀完2",CharsetUtil.UTF_8));}});System.out.println("繼續(xù)執(zhí)行");} sc

4 用戶自定義定時(shí)任務(wù) 異步執(zhí)行(將任務(wù)提交到scheduleTaskQueue中)

/*** 讀取數(shù)據(jù)事件(這里我們可以讀取客戶端發(fā)送的消息)* @param ctx 上下文對(duì)象,包含了管道pipeline(做業(yè)務(wù)邏輯) 通道channel(做數(shù)據(jù)讀寫) 地址等* @param msg 客戶端發(fā)送的數(shù)據(jù),默認(rèn)Object*/@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {//這里有一個(gè)非常耗時(shí)的時(shí)間業(yè)務(wù),---》異步執(zhí)行,提交到channel、對(duì)應(yīng)的 scheduleTaskQueuectx.channel().eventLoop().schedule(new Runnable() {@Overridepublic void run() {try {Thread.sleep(10*1000);} catch (InterruptedException e) {e.printStackTrace();}ctx.writeAndFlush(Unpooled.copiedBuffer("hello-客戶端-讀完",CharsetUtil.UTF_8));}},5, TimeUnit.SECONDS);//參數(shù):線程,時(shí)間,時(shí)間參數(shù)System.out.println("繼續(xù)執(zhí)行");}

5 FutureListener 監(jiān)聽事件

例如:我們的服務(wù)端執(zhí)行了 bootstrap.bind(6668).sync(); 得到ChannelFuture

//給我們服務(wù)端綁定端口并且同步處理,生成一個(gè)ChannelFuture,啟動(dòng)服務(wù)器ChannelFuture channelFuture = bootstrap.bind(6668).sync();//使用FutureListener 給channelFuture 注冊(cè)監(jiān)聽器,監(jiān)控綁定成功的時(shí)間channelFuture.addListener(new ChannelFutureListener() {@Overridepublic void operationComplete(ChannelFuture channelFuture) throws Exception {if (channelFuture.isSuccess()){System.out.println("監(jiān)聽端口6668成功");} else {System.out.println("監(jiān)聽端口6668失敗");}}});

6 HTTP案例

6.1 TestHTTPServer

package com.fs.netty.http;import io.netty.bootstrap.ServerBootstrap; import io.netty.channel.ChannelFuture; import io.netty.channel.ChannelFutureListener; import io.netty.channel.EventLoopGroup; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.nio.NioServerSocketChannel;/* http案例*/ public class TestHTTPServer {public static void main(String[] args) throws InterruptedException {EventLoopGroup bossGroup = new NioEventLoopGroup(1);EventLoopGroup workerGroup = new NioEventLoopGroup();try {ServerBootstrap serverBootstrap = new ServerBootstrap();serverBootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).childHandler(new TestServerInitialize());//使用自定義的解碼器ChannelFuture channelFuture = serverBootstrap.bind(8080).sync();channelFuture.addListener(new ChannelFutureListener() {@Overridepublic void operationComplete(ChannelFuture channelFuture) throws Exception {if (channelFuture.isSuccess()){System.out.println("監(jiān)聽8080成功");}else {System.out.println("監(jiān)聽8080失敗");}}});channelFuture.channel().closeFuture().sync();}finally {bossGroup.shutdownGracefully();bossGroup.shutdownGracefully();}} }

6.2 TestServerInitialize

package com.fs.netty.http;import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelPipeline; import io.netty.channel.socket.SocketChannel; import io.netty.handler.codec.http.HttpServerCodec;public class TestServerInitialize extends ChannelInitializer<SocketChannel> {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {//向管道加入處理器//得到管道ChannelPipeline pipeline = socketChannel.pipeline();//加入netty提供的httpServerCodec codec 是編解碼器//HttpServerCodec是netty提供的http的編解碼器pipeline.addLast("MyHttpServerCodec",new HttpServerCodec());//增加一個(gè)自己的處理器pipeline.addLast("MyTestServerHandler",new TestServerHandler());}@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {ctx.close();} }

6.3 TestServerHandler

package com.fs.netty.http;import io.netty.buffer.ByteBuf; import io.netty.buffer.Unpooled; import io.netty.channel.ChannelHandler; import io.netty.channel.ChannelHandlerContext; import io.netty.channel.SimpleChannelInboundHandler; import io.netty.handler.codec.http.*; import io.netty.util.CharsetUtil;/* 自定義handlerSimpleChannelInboundHandler 是ChannelInboundHandlerAdapter的子類 HttpObject 表示的客戶端和服務(wù)器端相互通信的數(shù)據(jù)被封裝成httpObject*/ public class TestServerHandler extends SimpleChannelInboundHandler<HttpObject> {/*** 讀取客戶端數(shù)據(jù)* @param channelHandlerContext 上下文* @param msg 封裝的消息為HttpObject*/@Overrideprotected void channelRead0(ChannelHandlerContext channelHandlerContext, HttpObject msg) throws Exception {//判斷msg是不是HttpRequest請(qǐng)求if (msg instanceof HttpRequest){System.out.println("msg 類型 = " + msg.getClass());System.out.println("客戶端地址 : "+ channelHandlerContext.channel().remoteAddress());//回復(fù)信息給瀏覽器,要發(fā)送http協(xié)議信息ByteBuf byteBuf = Unpooled.copiedBuffer("Hello-我是服務(wù)器", CharsetUtil.UTF_8);//構(gòu)造一個(gè)http的響應(yīng),即 httpResponse//參數(shù):HTTP版本 HTTP詳情狀態(tài)碼 響應(yīng)內(nèi)容HttpResponse defaultHttpResponse = new DefaultFullHttpResponse(HttpVersion.HTTP_1_1, HttpResponseStatus.OK, byteBuf);//設(shè)置其他的信息defaultHttpResponse.headers().set(HttpHeaderNames.CONTENT_TYPE,"text/plain");//設(shè)置返回參數(shù)類型defaultHttpResponse.headers().set(HttpHeaderNames.CONTENT_LENGTH,byteBuf.readableBytes());//設(shè)置返回參數(shù)長(zhǎng)度//將數(shù)據(jù)寫入并刷新channelHandlerContext.writeAndFlush(defaultHttpResponse);}}@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {ctx.close();} }

執(zhí)行結(jié)果

7 Unpooled對(duì)象

7.1 Unpooled案例1 ByteBuf的使用1

package com.fs.netty.buf;import io.netty.buffer.ByteBuf; import io.netty.buffer.Unpooled;public class NettyByteBuf01 {public static void main(String[] args) {//向創(chuàng)建一個(gè)bytebuf//說(shuō)明:先創(chuàng)建對(duì)象,該對(duì)象包含一個(gè)byte數(shù)組,是一個(gè)byte[10]//在netty的buffer中不需要slip進(jìn)行反轉(zhuǎn),//因?yàn)樗S護(hù)了 readerindex 和 writeindex 和 capacity ,將buffer分成了三個(gè)區(qū)域//0----》readerindex已經(jīng)讀取的區(qū)域//readerindex-----》writeindex 可讀的區(qū)域//writeindex------》capacity 表示可寫的區(qū)域ByteBuf buffer = Unpooled.buffer(10);for (int i = 0; i < 10; i++) {buffer.writeByte(i);}//通過(guò)debug就可以看到readerindex和writeindex在不斷的變化System.out.println("capacity:"+buffer.capacity());//輸出for (int i= 0;i<buffer.capacity();i++){ // System.out.println(buffer.getByte(i));//這個(gè)不會(huì)照成readerindex變化,因?yàn)橹付怂饕?/span>System.out.println(buffer.readByte());//這會(huì)照成readerindex變化}} }

7.2 Unpooled案例2 ByteBuf的使用2

package com.fs.netty.buf;import io.netty.buffer.ByteBuf; import io.netty.buffer.Unpooled; import io.netty.util.CharsetUtil;import java.nio.charset.Charset;public class NettyByteBuf02 {public static void main(String[] args) {//向創(chuàng)建一個(gè)bytebufByteBuf byteBuf = Unpooled.copiedBuffer("hello,world", CharsetUtil.UTF_8);//使用相關(guān)方法if (byteBuf.hasArray()){byte[] content = byteBuf.array();//將 content 轉(zhuǎn)成字符串System.out.println(new String(content, Charset.forName("utf-8")));//byteBuf=UnpooledByteBufAllocator$InstrumentedUnpooledUnsafeHeapByteBuf(ridx: 0, widx: 11, cap: 33)System.out.println("byteBuf="+byteBuf);System.out.println(byteBuf.arrayOffset());//0System.out.println(byteBuf.readerIndex());//0System.out.println(byteBuf.writerIndex());//11System.out.println(byteBuf.capacity());//33//由此可得,copiedBuffer這樣的方式創(chuàng)建的byteBuf的容量不是給定的字符串的大小System.out.println(byteBuf.readableBytes());//11System.out.println(byteBuf.readByte());//這里讀一下 值:104 因?yàn)镠的阿斯克碼是104System.out.println(byteBuf.readableBytes());//10}} }

8 Netty實(shí)現(xiàn)群聊系統(tǒng)

8.1服務(wù)端

GroupChatServer

package com.fs.netty.groupchat.server;import io.netty.bootstrap.ServerBootstrap; import io.netty.channel.*; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.nio.NioServerSocketChannel; import io.netty.handler.codec.string.StringDecoder; import io.netty.handler.codec.string.StringEncoder;/* 群聊服務(wù)端*/ public class GroupChatServer {private int port;public GroupChatServer(int port){this.port = port;}//編寫一個(gè)run方法,處理客戶端的請(qǐng)求public void run() throws InterruptedException {//創(chuàng)建兩個(gè)線程組EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();try {ServerBootstrap serverBootstrap = new ServerBootstrap();serverBootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).option(ChannelOption.SO_BACKLOG,128).childOption(ChannelOption.SO_KEEPALIVE,true).childHandler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {//獲取到pipelineChannelPipeline pipeline = socketChannel.pipeline();//向pipeline加入解碼器pipeline.addLast("decoder",new StringDecoder());//向pipeline加入編碼器pipeline.addLast("encoder",new StringEncoder());//加入自己的業(yè)務(wù)處理類pipeline.addLast(new GroupChatServerHandler());}});System.out.println("netty服務(wù)器已啟動(dòng):"+port);ChannelFuture channelFuture = serverBootstrap.bind(port).sync();//監(jiān)聽關(guān)閉channelFuture.channel().closeFuture().sync();}finally {bossGroup.shutdownGracefully();workerGroup.shutdownGracefully();}}public static void main(String[] args) throws InterruptedException {GroupChatServer groupChatServer = new GroupChatServer(7000);groupChatServer.run();} }

GroupChatServerHandler

package com.fs.netty.groupchat.server;import io.netty.channel.Channel; import io.netty.channel.ChannelHandlerContext; import io.netty.channel.SimpleChannelInboundHandler; import io.netty.channel.group.ChannelGroup; import io.netty.channel.group.DefaultChannelGroup; import io.netty.util.concurrent.EventExecutor; import io.netty.util.concurrent.GlobalEventExecutor;import java.text.SimpleDateFormat; import java.util.Date;//創(chuàng)建服務(wù)端處理器,指定發(fā)送數(shù)據(jù)為String,重寫channelRead0方法 public class GroupChatServerHandler extends SimpleChannelInboundHandler<String> {//定義一個(gè)channle組,管理所有的channel// GlobalEventExecutor.INSTANCE 是全局的事件執(zhí)行器,是一個(gè)單列private static ChannelGroup channelGroup = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//handlerAdded 表示鏈接建立,一旦鏈接,第一個(gè)執(zhí)行//一旦鏈接,將當(dāng)前的channel加入到 channelGroup@Overridepublic void handlerAdded(ChannelHandlerContext ctx) throws Exception {Channel channel = ctx.channel();//將該客戶加入聊天的信息推送給其他在線的客戶端//channelGroup.writeAndFlush 該方法回將channelGroup中所有的channel便利,并發(fā)送信息channelGroup.writeAndFlush(simpleDateFormat.format(new Date())+"[客戶端]"+channel.remoteAddress()+"加入聊天\n");channelGroup.add(channel);}/*** 表示channel處于活動(dòng)狀態(tài),,提示某某上線*/@Overridepublic void channelActive(ChannelHandlerContext ctx) throws Exception {System.out.println(ctx.channel().remoteAddress()+":上線了");}/*** 當(dāng)channel處于非活動(dòng)狀態(tài),提示離線了* @param ctx* @throws Exception*/@Overridepublic void channelInactive(ChannelHandlerContext ctx) throws Exception {System.err.println(ctx.channel().remoteAddress()+":離線了");}/*** 表示斷開鏈接觸發(fā),將某某客戶離開信息推送給當(dāng)前在線的客戶*/@Overridepublic void handlerRemoved(ChannelHandlerContext ctx) throws Exception {Channel channel = ctx.channel();channelGroup.writeAndFlush(simpleDateFormat.format(new Date())+"[客戶端]"+channel.remoteAddress()+"離開了\n");//這個(gè)方法執(zhí)行后,當(dāng)前Channel會(huì)自動(dòng)從channelGroup中移除System.out.println("當(dāng)前channelGroup大小:"+channelGroup.size());}/*** 讀取數(shù)據(jù),將數(shù)據(jù)轉(zhuǎn)發(fā)所有在線的人員*/@Overrideprotected void channelRead0(ChannelHandlerContext channelHandlerContext, String msg) throws Exception {//獲取當(dāng)前channelChannel channel = channelHandlerContext.channel();//這時(shí)遍歷channelGroup,根據(jù)不同情況回送不同的消息channelGroup.forEach(ch -> {if (ch != channel) {//說(shuō)明不是當(dāng)前的channel、就轉(zhuǎn)發(fā)消息ch.writeAndFlush(simpleDateFormat.format(new Date())+"[客戶]"+channel.remoteAddress() + " 發(fā)送了消息:"+msg+"\n");}else {//顯示下自己發(fā)送的消息ch.writeAndFlush(simpleDateFormat.format(new Date())+"[自己]發(fā)送了消息"+msg+"\n");}});}/*** 異常處理*/@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {//關(guān)閉通道ctx.close();} }

8.2 客戶端

GroupChatClient

package com.fs.netty.groupchat.client;import io.netty.bootstrap.Bootstrap; import io.netty.channel.*; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.nio.NioSocketChannel; import io.netty.handler.codec.string.StringDecoder; import io.netty.handler.codec.string.StringEncoder;import java.util.Scanner;/* 群聊客戶端*/ public class GroupChatClient {private final String host;private final int port;public GroupChatClient(String host,int port){this.host = host;this.port = port;}public void run() throws InterruptedException {EventLoopGroup eventLoopGroup = new NioEventLoopGroup();Bootstrap bootstrap = new Bootstrap();try {bootstrap.group(eventLoopGroup).channel(NioSocketChannel.class).handler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {ChannelPipeline pipeline = socketChannel.pipeline();//加入相關(guān)的handlerpipeline.addLast("decoder",new StringDecoder());pipeline.addLast("encoder",new StringEncoder());//加入自己的處理器pipeline.addLast(new GroupChatClientHandler());}});ChannelFuture channelFuture = bootstrap.connect(host, port).sync();Channel channel = channelFuture.channel();System.out.println(channel.localAddress()+"客戶端已經(jīng)準(zhǔn)備好了");//客戶端輸入信息,創(chuàng)建掃描器Scanner scanner = new Scanner(System.in);while (scanner.hasNextLine()){String s = scanner.nextLine();//通過(guò)channel發(fā)送服務(wù)器端channel.writeAndFlush(s+"\r\n");}}finally {eventLoopGroup.shutdownGracefully();}}public static void main(String[] args) throws InterruptedException {GroupChatClient groupChatClient = new GroupChatClient("127.0.0.1", 7000);groupChatClient.run();} }

GroupChatClientHandler

package com.fs.netty.groupchat.client;import io.netty.channel.ChannelHandlerContext; import io.netty.channel.SimpleChannelInboundHandler;/* 客戶端處理,接受String、*/ public class GroupChatClientHandler extends SimpleChannelInboundHandler<String> {/*讀取消息*/@Overrideprotected void channelRead0(ChannelHandlerContext channelHandlerContext, String msg) throws Exception {System.out.println("[服務(wù)端發(fā)送的消息] "+ msg);} }

8.3 運(yùn)行效果


9 netty心跳處理(讀寫空閑)

HeartbeatNettyServer

package com.fs.netty.heartbeat;import io.netty.bootstrap.ServerBootstrap; import io.netty.channel.ChannelFuture; import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelPipeline; import io.netty.channel.EventLoopGroup; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.nio.NioServerSocketChannel; import io.netty.handler.logging.LogLevel; import io.netty.handler.logging.LoggingHandler; import io.netty.handler.timeout.IdleStateHandler;import java.util.concurrent.TimeUnit;/*** netty心跳機(jī)制*/ public class HeartbeatNettyServer {public static void main(String[] args) throws InterruptedException {EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();try {ServerBootstrap serverBootstrap = new ServerBootstrap();serverBootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).handler(new LoggingHandler(LogLevel.INFO))//加入日志處理類.childHandler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {ChannelPipeline pipeline = socketChannel.pipeline();//加入一個(gè)netty提供的 IdleStateHandler 處理空閑狀態(tài)的處理器//參數(shù)說(shuō)明//1.long readerIdleTime,表示多長(zhǎng)時(shí)間沒(méi)有讀了,就會(huì)發(fā)送一個(gè)心跳檢測(cè)包//2. long writerIdleTime,表示多長(zhǎng)時(shí)間沒(méi)有寫了。就會(huì)發(fā)送一個(gè)心跳檢測(cè)包//3. long allIdleTime,表示多長(zhǎng)時(shí)間沒(méi)有讀寫了,就會(huì)發(fā)送一個(gè)心跳檢測(cè)包//4 unit 時(shí)間單位//當(dāng)IdleStateEvent觸發(fā)后,就會(huì)傳遞給管道的下一個(gè)handler去處理//通過(guò)調(diào)用(觸發(fā))下一個(gè)handler 的 userEventTinggered。在該方法中去處理,pipeline.addLast(new IdleStateHandler(3,5,7, TimeUnit.SECONDS));//加入一個(gè)空閑檢測(cè)進(jìn)一步處理的handler(自定義)pipeline.addLast(new HeartbeatNettyHandler());}});//啟動(dòng)服務(wù)器ChannelFuture channelFuture = serverBootstrap.bind(7000).sync();channelFuture.channel().closeFuture().sync();}finally {bossGroup.shutdownGracefully();workerGroup.shutdownGracefully();}} }

HeartbeatNettyHandler

package com.fs.netty.heartbeat;import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelInboundHandlerAdapter; import io.netty.handler.timeout.IdleStateEvent;public class HeartbeatNettyHandler extends ChannelInboundHandlerAdapter {/*** @param ctx 上下文* @param evt 事件*/@Overridepublic void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception {if (evt instanceof IdleStateEvent) {//將evt 向下轉(zhuǎn)型 成IdleStateEventIdleStateEvent event = (IdleStateEvent) evt;String eventType = null;switch (event.state()) {case READER_IDLE:eventType = "讀空閑";break;case WRITER_IDLE:eventType = "寫空閑";break;case ALL_IDLE:eventType = "讀寫空閑";break;}System.out.println(ctx.channel().remoteAddress() + "---超時(shí)事件---" + eventType);System.out.println("服務(wù)器做相應(yīng)處理");//如果發(fā)生空閑,我們關(guān)閉通道ctx.channel().close();}} }

10 WebSocket案例

案例運(yùn)行結(jié)果
先運(yùn)行服務(wù),后打開html

MyServer

package com.fs.netty.websocket;import com.fs.netty.heartbeat.HeartbeatNettyHandler; import io.netty.bootstrap.ServerBootstrap; import io.netty.channel.ChannelFuture; import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelPipeline; import io.netty.channel.EventLoopGroup; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.nio.NioServerSocketChannel; import io.netty.handler.codec.http.HttpObjectAggregator; import io.netty.handler.codec.http.HttpServerCodec; import io.netty.handler.codec.http.websocketx.WebSocketServerProtocolHandler; import io.netty.handler.logging.LogLevel; import io.netty.handler.logging.LoggingHandler; import io.netty.handler.stream.ChunkedWriteHandler;public class MyServer {public static void main(String[] args) throws InterruptedException {EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();try {ServerBootstrap serverBootstrap = new ServerBootstrap();serverBootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).handler(new LoggingHandler(LogLevel.INFO))//加入日志處理類.childHandler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {ChannelPipeline pipeline = socketChannel.pipeline();//因?yàn)槭腔贖TTP協(xié)議的,因此使用HTTP的編解碼器pipeline.addLast(new HttpServerCodec());//是以塊方式寫的,添加ChunkedWriteHeandlerpipeline.addLast(new ChunkedWriteHandler());/*1.因?yàn)镠TTP數(shù)據(jù)在傳輸過(guò)程中是分段。HttpObjectAggregator 就是可以將多個(gè)段聚合起來(lái)2.這就是為什么當(dāng)瀏覽器發(fā)送大量數(shù)據(jù)時(shí),就會(huì)發(fā)出多次http請(qǐng)求的原因*/pipeline.addLast(new HttpObjectAggregator(8192));/*對(duì)于websocket,他的數(shù)據(jù)是以幀的形式傳遞的可以看到websocketFrame類下面有六個(gè)子類瀏覽器請(qǐng)求時(shí)候,ws://localhost:7000/hello 表示請(qǐng)求的uriWebSocketServerProtocolHandler 核心功能。是將HTTP協(xié)議升級(jí)為WS協(xié)議,即websocket協(xié)議,即長(zhǎng)連接*/pipeline.addLast(new WebSocketServerProtocolHandler("/hello"));//自定義的handler,處理業(yè)務(wù)邏輯pipeline.addLast(new MyWebSocketFrameHandler());}});//啟動(dòng)服務(wù)器ChannelFuture channelFuture = serverBootstrap.bind(7000).sync();channelFuture.channel().closeFuture().sync();}finally {bossGroup.shutdownGracefully();workerGroup.shutdownGracefully();}} }

MyWebSocketFrameHandler

package com.fs.netty.websocket;import io.netty.channel.ChannelHandlerContext; import io.netty.channel.SimpleChannelInboundHandler; import io.netty.handler.codec.http.websocketx.TextWebSocketFrame;import java.time.LocalDateTime;//自定義的handler //TextWebSocketFrame 表示一個(gè)文本幀 public class MyWebSocketFrameHandler extends SimpleChannelInboundHandler<TextWebSocketFrame> {@Overrideprotected void channelRead0(ChannelHandlerContext channelHandlerContext, TextWebSocketFrame msg) throws Exception {System.out.println("服務(wù)器收到的消息:"+msg.text());//回復(fù)客戶端channelHandlerContext.channel().writeAndFlush(new TextWebSocketFrame("服務(wù)器時(shí)間:"+ LocalDateTime.now()+",收到的消息:"+msg.text()));}/*當(dāng)web客戶端鏈接后就會(huì)觸發(fā)這個(gè)方法*/@Overridepublic void handlerAdded(ChannelHandlerContext ctx) throws Exception {//id 表示唯一值,asLongText 是唯一的,asShortText不是唯一的,有可能重復(fù)System.out.println("handlerAdded 被調(diào)用:"+ctx.channel().id().asLongText());System.out.println("handlerAdded 被調(diào)用:"+ctx.channel().id().asShortText());}//當(dāng)鏈接中斷會(huì)調(diào)用。@Overridepublic void handlerRemoved(ChannelHandlerContext ctx) throws Exception {System.out.println("handlerRemoved 被調(diào)用:"+ctx.channel().id().asLongText());}//處理異常@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {System.out.println("異常發(fā)送:"+cause.getMessage());//關(guān)閉通道ctx.close();} }

hello.html

<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Title</title> </head> <body> <script>var socket;//判斷當(dāng)前瀏覽器是否支持websocket編程if (window.WebSocket){socket = new WebSocket("ws://localhost:7000/hello");//相當(dāng)于channelRead0 ev 收到服務(wù)器端回送的消息socket.onmessage = function (ev){var rt = document.getElementById("responseText");rt.value = rt.value+"\n"+ev.data;}//相當(dāng)于連接服務(wù)器開啟socket.onopen = function (ev){var rt = document.getElementById("responseText");rt.value = "連接開啟"}//連接關(guān)閉socket.onclose = function (ev){var rt = document.getElementById("responseText");rt.value = rt.value+"\n"+"連接關(guān)閉了";}//發(fā)送消息到服務(wù)器function send(message){//判斷socket是否創(chuàng)建好if (!window.socket){return;}//判斷連接是否開啟if (socket.readyState == WebSocket.OPEN){//通過(guò)socket 發(fā)送消息socket.send(message)}else {alert("連接沒(méi)有開啟")}}}else {alert("您當(dāng)前的瀏覽器不支持webSocket")} </script><form onsubmit="return false"><textarea name="message" style="height: 300px;width: 300px"></textarea><input type="button" value="發(fā)送消息" onclick="send(this.form.message.value)"><textarea id="responseText" style="height: 300px;width: 300px"></textarea><input type="button" value="清空內(nèi)容" onclick="document.getElementById('responseText').value=''"></form> </body> </html>

總結(jié)

以上是生活随笔為你收集整理的Netty-案例 WebSocket与netty实现长连接案例(代码注释详解)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

日日夜夜天天 | 草久在线播放 | 国产精久久 | 丁香五婷 | 国产精品综合av一区二区国产馆 | 免费在线观看一级片 | 操操日| 91九色在线视频观看 | 国产黑丝一区二区三区 | 国产一区二区视频在线播放 | 91热这里只有精品 | 成片视频免费观看 | 日韩高清在线一区二区 | 一本—道久久a久久精品蜜桃 | 国产成人精品一区二区 | 亚洲国产成人精品电影在线观看 | 97久久精品午夜一区二区 | 天操夜夜操| 国产精品欧美一区二区三区不卡 | 成人性生交大片免费看中文网站 | 亚州精品在线视频 | 精品少妇一区二区三区在线 | 久久久国产电影 | 亚洲婷婷综合色高清在线 | 日韩在线视频看看 | 欧美日韩免费观看一区二区三区 | 欧美福利在线播放 | 久久久天堂 | 人人草人人草 | 999色视频| 狠狠色丁香久久婷婷综合五月 | 国产欧美日韩视频 | 人人爽人人爽人人爽学生一级 | 国产一线二线三线性视频 | 99视频在线观看一区三区 | 日本视频不卡 | 激情图片区 | 欧美激情综合五月色丁香小说 | 国产视频日本 | 成人免费在线观看av | 人人澡人人爽欧一区 | 欧美极品xxx| 国产精品免费av | 国产精选在线观看 | 亚洲精品一区中文字幕乱码 | 最新国产精品拍自在线播放 | 精品国产美女 | av黄在线播放 | 国产免费三级在线观看 | 丰满少妇高潮在线观看 | 国产精品麻豆91 | 久久久不卡影院 | 国产精品久久久久婷婷 | 中文乱幕日产无线码1区 | 午夜电影av | 欧美精品免费在线 | 黄色小说视频在线 | 日韩欧美在线免费 | 久久精品美女视频网站 | 久久久久久久久久久成人 | 亚洲激情六月 | 2020天天干夜夜爽 | 91色在线观看 | 日本公妇色中文字幕 | 碰超在线 | 深夜免费网站 | 日韩高清一区 | 久久国产美女 | 亚洲涩涩涩 | 久久狠狠婷婷 | 久久久综合九色合综国产精品 | 久久精品人 | 韩国精品一区二区三区六区色诱 | 伊人久久影视 | 欧美日韩国产精品久久 | 久久久久在线 | 国产91大片 | 国产色视频一区二区三区qq号 | 国产黄色免费 | 国产福利av在线 | 欧美日韩精品在线观看 | 午夜视频在线观看一区二区 | 激情五月色播五月 | 国产精品久久久久一区二区三区 | 亚洲人成免费网站 | av大全在线看 | 国产精品123 | 91久久精品一区二区二区 | 成人99免费视频 | 婷婷婷国产在线视频 | 91色蜜桃 | 国外av在线 | 国产精品一区在线观看你懂的 | 国产精品久久久久久久久搜平片 | 中文字幕在线观看视频一区二区三区 | 黄色在线看网站 | 日韩精品免费在线视频 | 免费观看www7722午夜电影 | 福利一区视频 | 欧美老少交 | 日韩日韩日韩日韩 | 午夜少妇一区二区三区 | 国产理伦在线 | 欧美午夜精品久久久久久孕妇 | 久久久私人影院 | 男女视频91 | 日韩欧美电影在线 | 精品一区二区精品 | 99久久久国产精品免费观看 | 91 在线视频 | 成人在线视频免费看 | 亚洲电影久久 | 岛国一区在线 | 亚洲开心激情 | 国产 日韩 欧美 中文 在线播放 | 成人黄大片视频在线观看 | 亚洲成人黄色 | 黄色av免费电影 | 一级a毛片高清视频 | 国产一区二区不卡视频 | 深爱激情亚洲 | 久久综合一本 | 亚洲精品免费在线播放 | 激情久久一区二区三区 | 精品亚洲在线 | 91看片在线免费观看 | 国产一级精品视频 | 97香蕉超级碰碰久久免费软件 | 黄色影院在线免费观看 | 日日夜夜精品免费 | 精品国产乱码久久 | 99久久精品日本一区二区免费 | 久久久久久免费视频 | 国产精品黄色 | 久久99视频免费 | 婷婷在线免费观看 | 九九热免费在线观看 | 久操免费视频 | 成人黄色小说网 | 九草视频在线观看 | 三级黄在线 | 国产一级性生活视频 | av免费在线看网站 | 日韩在线观看的 | 中文字幕第一页在线vr | 亚洲综合色激情五月 | mm1313亚洲精品国产 | 操操操操网 | 丁香免费视频 | 国产 日韩 欧美 中文 在线播放 | 国产精品亚洲成人 | 日韩午夜三级 | 黄色av一区二区三区 | av在线中文 | 日韩欧美一区二区三区视频 | 天天综合网入口 | 99精品一级欧美片免费播放 | 久久精品国产一区 | 成年人在线观看网站 | www.天天成人国产电影 | www.香蕉 | 在线视频app | 国产精品无av码在线观看 | 亚洲成a人片77777kkkk1在线观看 | 免费看黄色大全 | 国产丝袜美腿在线 | 日韩精品短视频 | 少妇bbbb| 一级免费av | 国产精品久久99综合免费观看尤物 | 激情久久久久久久久久久久久久久久 | 精品久久久久久久久久久久久 | 亚欧日韩成人h片 | 亚洲精品视频网 | av网址aaa| 国产高清精品在线观看 | 天天干,夜夜操 | 久草精品资源 | 成人免费在线电影 | 精品在线免费观看 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 99在线免费观看视频 | 日韩av一区二区三区 | 一区二区三区在线不卡 | 日韩精品一区二区三区不卡 | 欧美巨乳网| 久久精品79国产精品 | 亚洲成a人片在线www | 九九九九热精品免费视频点播观看 | 日本女人b| 欧美色就是色 | 五月激情在线 | 成人国产精品 | 亚洲视频在线视频 | 国产精品高潮久久av | 欧美精品三级在线观看 | 91精品91 | 国产国产人免费人成免费视频 | 麻豆视频在线 | 国产高清视频在线免费观看 | 免费精品在线 | 99精品视频在线观看视频 | 亚洲精品tv久久久久久久久久 | 国产视频手机在线 | 黄色中文字幕在线 | 久久九九久久 | 久久免费激情视频 | www中文在线 | 久久五月婷婷丁香 | 综合网av | 一区二区三区在线免费观看 | 国产亚洲精品久久久久久久久久 | 91在线视频一区 | 精品女同一区二区三区在线观看 | 美女网站色 | 中文字幕在线视频精品 | 狠狠色噜噜狠狠狠狠2021天天 | 亚洲精品一区中文字幕乱码 | 精品96久久久久久中文字幕无 | 成人久久久精品国产乱码一区二区 | 在线 你懂| 久久视频在线免费观看 | 丁香婷婷综合激情 | 精品在线播放视频 | 国产福利av在线 | 国产色一区 | 久久精品这里都是精品 | 成人福利在线 | 在线a视频 | 天天插天天射 | a√国产免费a | 中文字幕av日韩 | 亚洲精品大片www | av在观看| 奇米影视8888在线观看大全免费 | www.玖玖玖| 国产精品一区在线 | 久久五月情影视 | 免费a一级 | 最新av免费在线 | 免费网站v | 国产中文视频 | 国产高清久久久 | 欧美成人理伦片 | 二区视频在线观看 | 天天插天天色 | 99久久精品免费看国产四区 | 国产精品久久久久久久久久尿 | 国产高清无线码2021 | 91.麻豆视频| 丁香久久五月 | 91精品国产92久久久久 | 黄色www在线观看 | 天天综合视频在线观看 | 91av在线播放 | 日韩字幕在线观看 | 中文字幕九九 | 国产日韩欧美视频 | 91九色自拍| 亚洲伦理精品 | 天堂资源在线观看视频 | 奇米先锋 | 欧美调教网站 | 亚洲欧美日韩一区二区三区在线观看 | 激情综合网五月婷婷 | 人人舔人人舔 | 国产精品久久久久av | 黄色影院在线观看 | 欧美亚洲专区 | 在线观看日本高清mv视频 | 在线播放 亚洲 | www亚洲精品 | 国产欧美精品一区二区三区 | 麻花豆传媒一二三产区 | 亚洲综合色播 | 久久综合五月婷婷 | 久久99精品国产91久久来源 | 精品国产一区二区三区久久久 | 久久国产综合视频 | 99国产免费网址 | 黄网站色欧美视频 | 日韩久久久久久久 | 在线天堂视频 | 日韩黄在线观看 | 国产中文在线字幕 | 欧美做受xxx | 日韩激情一二三区 | 久久久久久久久久久国产精品 | 国产在线久草 | 99在线精品观看 | 乱男乱女www7788| 国产日韩欧美在线看 | 天天爽人人爽夜夜爽 | 亚洲国内精品在线 | 毛片在线网 | 欧美极品少妇xbxb性爽爽视频 | 91精品成人久久 | 国产99久久久国产精品免费二区 | 欧美另类激情 | 欧美大片在线观看一区 | 成人黄色中文字幕 | 制服丝袜一区二区 | 久久精品伊人 | 特级a毛片 | 国产裸体bbb视频 | 欧美日韩另类在线 | 久福利| 久久久久久久久久久久久久电影 | 国产这里只有精品 | 在线成人高清电影 | 久久综合中文字幕 | 五月天激情综合网 | 欧美一区日韩精品 | 亚洲精品一区二区精华 | 超碰免费在线公开 | 最新国产精品亚洲 | 亚洲综合激情网 | 欧洲精品久久久久毛片完整版 | 久久影院亚洲 | 久久久福利 | 在线播放一区二区三区 | 六月丁香在线视频 | 欧美日韩国产免费视频 | 人人澡人人模 | 日韩精品一区电影 | av电影在线观看完整版一区二区 | 国产精品久久久久久久久久新婚 | 国产视频 亚洲视频 | 久热只有精品 | 狠狠干 狠狠操 | 一区中文字幕电影 | 国产福利在线 | 亚洲在线色| 欧美精品在线观看一区 | www五月婷婷 | 99成人免费视频 | 欧美精品久久久久久久亚洲调教 | 91禁在线看| 亚洲精品九九 | av在线观 | 亚洲国产大片 | 欧美日韩高清在线一区 | 美女黄频| 在线观看视频国产一区 | 亚洲日本韩国一区二区 | www.在线观看av | 国产一线在线 | 中文字幕一区二 | 日韩在线视频网 | www.91av在线| 99 色 | 91精品一区二区三区久久久久久 | 天天色天天操天天爽 | 天天操天天操天天操天天操天天操 | 久久久九色精品国产一区二区三区 | 欧美五月婷婷 | 在线观看日本韩国电影 | 免费看久久久 | 五月香婷 | 欧美精品久久人人躁人人爽 | 国产91精品在线播放 | 综合精品久久久 | 日韩二区精品 | 国产福利精品在线观看 | 久久天天躁狠狠躁夜夜不卡公司 | av夜夜操 | 国产区 在线 | 久操综合| 在线亚洲精品 | 色网站视频| 日韩视频免费 | www.com黄色| 色91在线视频 | 在线看av网址 | 国产视频一区在线播放 | 四虎成人免费影院 | 日韩成人欧美 | 亚洲国产精品传媒在线观看 | 成人在线免费观看网站 | 在线99热 | 91片在线观看| 精品在线视频一区 | 天天综合亚洲 | 日本中文一级片 | 在线国产视频观看 | av在线一二三区 | 欧美日韩中文在线视频 | aaa日本高清在线播放免费观看 | 欧美精品久 | 国产精品1区2区在线观看 | 黄色av播放 | 国产高清亚洲 | 久久天天躁夜夜躁狠狠85麻豆 | 福利电影久久 | 国产专区在线 | 91九色视频观看 | 精品嫩模福利一区二区蜜臀 | 国产精国产精品 | 欧美在线视频日韩 | 久久免费视频在线观看 | 天天射天天干天天操 | 亚洲综合在线视频 | 亚洲精品99 | 手机在线看a | 91av在线视频免费观看 | 69精品视频在线观看 | 日韩精品中文字幕一区二区 | 最近中文字幕免费视频 | 91久色蝌蚪 | 国产免费小视频 | 国产精品乱码高清在线看 | 好看的国产精品视频 | 97视频亚洲| 精品久久久久久亚洲综合网站 | 中文字幕在线色 | 免费日韩一级片 | 成人免费视频播放 | 久 久久影院 | 一区在线观看 | 人人爽人人爽av | 在线观看亚洲精品视频 | av在线永久免费观看 | 视色网站 | 欧美最爽乱淫视频播放 | 国产精品久久久久久久婷婷 | 欧美日韩亚洲在线观看 | 亚洲夜夜综合 | 中文字幕在线观看视频网站 | 狠狠操电影网 | 成人免费在线观看入口 | 国产成人精品女人久久久 | 日韩av高清在线观看 | 国产高清精品在线 | 日韩在线观看视频网站 | 蜜臀一区二区三区精品免费视频 | 成年人免费av网站 | 9999精品视频| 久艹视频在线免费观看 | 国产高清绿奴videos | 午夜精品视频免费在线观看 | 2021国产精品 | 九九视频在线观看视频6 | 99免在线观看免费视频高清 | 亚洲天天在线日亚洲洲精 | 天天爱综合 | av网站有哪些 | 九九久久精品视频 | 久久久久久久久久伊人 | 99九九视频| 激情五月激情综合网 | 黄色的视频网站 | 免费在线观看亚洲视频 | 国产人在线成免费视频 | 久久福利电影 | 亚洲国产三级 | 中文字幕 国产 一区 | 91中文字幕永久在线 | 2024av| 亚洲自拍偷拍色图 | 91中文在线观看 | 国产99久久久国产精品免费看 | 婷婷精品国产一区二区三区日韩 | 99re久久资源最新地址 | 欧美极品裸体 | 国产免费嫩草影院 | 亚洲无毛专区 | 五月开心六月婷婷 | 免费看片成年人 | 亚洲一区二区三区精品在线观看 | 亚洲成人精品久久久 | 人人讲 | 福利一区二区 | 国产一级免费在线观看 | www国产亚洲 | 中文字幕一区二区三区精华液 | 国产高清在线永久 | 精品国产一区二区三区四 | a在线观看免费视频 | 国产成人一区二区三区在线观看 | 久久免费试看 | 日本大片免费观看在线 | 欧美激情视频一二三区 | 国产 色 | 在线黄色毛片 | 免费进去里的视频 | 91视频高清免费 | 中文字幕在线视频一区二区三区 | 天天干,天天射,天天操,天天摸 | 91看片成人 | 嫩草伊人久久精品少妇av | 黄色软件在线观看 | 人人爽夜夜爽 | 麻豆视频观看 | 91九色蝌蚪国产 | 中文字幕在线日本 | 精品久久久久久久久久久久 | 久久不卡免费视频 | 天天插视频| 久久伦理影院 | 九九久久国产 | 伊人射 | 成人午夜精品 | 91成人精品国产刺激国语对白 | 亚洲综合最新在线 | 天天操天天射天天 | 国产一区二区不卡视频 | 亚洲小视频在线 | 国产精品1区2区3区 久久免费视频7 | 在线亚洲欧美视频 | 国产精品麻豆91 | 日韩中文字幕第一页 | 国产成人av网 | 精品亚洲视频在线观看 | 久久福利影视 | 日韩久久精品一区二区 | 国产一区二区三区免费在线观看 | 亚洲区二区 | 最新av观看 | 手机看片国产日韩 | 国产精品麻豆欧美日韩ww | 婷婷在线视频观看 | 色综合久久99 | 麻豆91网站 | 亚洲激情校园春色 | 天天天天天天天天操 | 在线观看蜜桃视频 | 免费观看一区二区三区视频 | 午夜色站 | 国产日韩欧美在线影视 | 国产亚洲视频在线观看 | 中文字幕乱偷在线 | 亚洲理论片在线观看 | 亚洲最新av在线网站 | 成人精品久久久 | av成人免费在线 | 亚洲最快最全在线视频 | 成人影音在线 | 成年人免费在线播放 | 欧美国产日韩激情 | 日本中文字幕一二区观 | 亚洲专区路线二 | 亚洲黄色成人av | 国产麻豆成人传媒免费观看 | 欧美精品久久久久a | 久久久久免费观看 | 日韩成人在线免费观看 | 人人藻人人澡人人爽 | 免费a级黄色毛片 | 国产v欧美 | 91av免费在线观看 | 91九色视频国产 | 国产在线观看地址 | 激情av资源 | 色视频国产直接看 | 国产精品男女视频 | 日韩激情精品 | 人人干人人干人人干 | 香蕉在线播放 | 99re亚洲国产精品 | 中文字幕一区二区三区乱码在线 | 日韩系列在线 | 在线观看一级 | 国产亚洲精品久久久久久无几年桃 | 日韩av一区二区三区四区 | 午夜美女福利 | 免费观看性生活大片 | 右手影院亚洲欧美 | 日韩av电影国产 | 亚洲精品高清一区二区三区四区 | 亚洲精品18日本一区app | 激情综合狠狠 | 久久99国产精品自在自在app | 婷婷电影在线观看 | 成人黄色大片在线观看 | 色资源在线 | 丝袜少妇在线 | 免费观看视频的网站 | 激情久久婷婷 | 天天天天天操 | 国产免费片 | 欧美 亚洲 另类 激情 另类 | 亚洲自拍偷拍色图 | 中文字幕高清在线播放 | 在线免费av网站 | 国产流白浆高潮在线观看 | 激情五月在线视频 | 激情久久伊人 | 久久在线影院 | 欧美在线91 | 国产亚洲精品久久久久秋 | 日本99久久 | 欧美视频日韩 | 97免费公开视频 | 成人av网站在线播放 | 亚洲国产小视频在线观看 | 日日碰狠狠躁久久躁综合网 | 久久久久久久久久福利 | 91九色porn在线资源 | 丁香六月网 | 色99在线| 午夜丁香视频在线观看 | 中文字幕av全部资源www中文字幕在线观看 | 91精品夜夜 | 国产精品一区二区久久精品爱涩 | 狠狠色丁香婷婷综合久小说久 | 欧美一级片在线观看视频 | 狠狠色噜噜狠狠狠狠 | 成人在线播放视频 | 人人澡人摸人人添学生av | 丁香六月在线 | 国产 一区二区三区 在线 | 国产无吗一区二区三区在线欢 | 国产精品久久久久av免费 | 激情久久综合网 | 日本69hd | 黄色免费大全 | 2019免费中文字幕 | 中文字幕亚洲欧美日韩 | 99视频网址 | 免费日韩电影 | 免费色av | 黄色a在线 | 日韩精品一区在线播放 | 91精品一区二区三区久久久久久 | 在线观看播放av | 91丨九色丨蝌蚪丰满 | 国产免费又粗又猛又爽 | 国产一区视频在线播放 | 午夜黄色一级片 | a天堂最新版中文在线地址 久久99久久精品国产 | 亚洲免费国产视频 | 国产高清成人 | av一级片| 久久精品国产第一区二区三区 | 五月天色站 | 亚洲h在线播放在线观看h | 99久久毛片 | 国产精品久久久久久爽爽爽 | 日韩欧美视频 | 欧美国产大片 | 国产精品福利午夜在线观看 | 一本一道久久a久久综合蜜桃 | 成人午夜免费福利 | 99久久免费看 | 成人免费看片网址 | 国产小视频你懂的 | 色香蕉在线| 九九久久免费 | 日韩欧美精选 | 最新久久免费视频 | 天天爱天天插 | 婷婷综合激情 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 99在线免费观看视频 | 国产一区二区在线免费播放 | 97色狠狠| 免费观看一区二区三区视频 | 黄在线免费看 | 美女网站在线看 | 精品亚洲免a | 成人三级网站在线观看 | 在线视频婷婷 | 日韩免费在线观看网站 | 欧美日韩高清 | 久久视频精品在线 | 成人欧美一区二区三区在线观看 | 国产在线播放一区 | 国产亚洲精品久久久久久网站 | 亚洲国产三级在线观看 | 国产福利91精品一区二区三区 | 乱男乱女www7788 | 国产高清视频在线播放一区 | 精品二区视频 | 夜夜爽www| 天天操天天射天天操 | 午夜精品视频福利 | 欧美在线一二 | 久热免费在线观看 | 丁香六月婷婷综合 | www.久久99 | 欧美日韩国产亚洲乱码字幕 | av免费网站| 精品久久久久久久久久久久久久久久久久 | 超碰在线公开免费 | 麻豆系列在线观看 | 久久精品一区二区国产 | 久久久午夜精品理论片中文字幕 | 在线观看成人av | 日韩激情小视频 | 在线影院 国内精品 | 国产一级大片在线观看 | 国产h在线播放 | 亚洲精品在线视频网站 | 91亚洲夫妻 | 欧美aaa级片 | 亚洲最新av网址 | 成人黄色大片 | 久草视频免费 | 免费三级av | 亚洲色图22p| 草久久久 | 免费看的黄色 | 婷婷激情综合五月天 | 久草av在线播放 | 欧美9999| 激情 亚洲| v片在线播放 | 最近中文字幕国语免费高清6 | 国产va在线观看免费 | 久久免费资源 | 天天操天天爽天天干 | 香蕉视频在线视频 | 久久热亚洲 | 国产裸体视频bbbbb | 欧美一区二区三区在线观看 | 日韩精品一区二区三区中文字幕 | 日本精品视频免费 | 亚洲人片在线观看 | 九九九九九精品 | 国产欧美综合视频 | 国产69精品久久99不卡的观看体验 | 久久久久北条麻妃免费看 | 成人在线视频观看 | 五月天综合激情网 | 国产欧美最新羞羞视频在线观看 | 五月黄色 | 五月丁色 | 久精品一区 | 中文字幕av在线播放 | 天天天在线综合网 | 98超碰在线| 欧美亚洲一区二区在线 | 91在线免费观看网站 | 一区二区三区四区久久 | 久久国产精品99久久久久久进口 | 日韩中文字幕网站 | 成人在线视频论坛 | 国产免费又爽又刺激在线观看 | 亚洲最新精品 | 亚洲精品视频在线观看免费视频 | 91精品影视| 日韩欧美视频在线 | 99综合电影在线视频 | 992tv在线观看| 午夜久久网站 | 色姑娘综合 | 一本一本久久a久久 | 国产亚洲精品久久久久久 | 欧美日韩不卡一区二区 | 日韩国产精品一区 | 美女av免费看 | 又色又爽又黄 | 国产欧美久久久精品影院 | 天天曰 | 在线黄频 | 美女精品久久久 | 国产不卡视频在线播放 | 91污污视频在线观看 | 这里只有精彩视频 | 在线观看av小说 | 久久一久久| 狠狠干夜夜操天天爽 | 国产精品一区二区电影 | 色www精品视频在线观看 | 欧美激情综合色综合啪啪五月 | 九色琪琪久久综合网天天 | 天天爽天天搞 | 色香蕉在线视频 | 亚洲视频在线观看免费 | 麻豆首页| 久久久国产电影 | 久久精品男人的天堂 | 日韩精品视频在线观看网址 | av大全在线观看 | 婷婷五天天在线视频 | 亚洲三级在线 | 国产v亚洲v | 久久免费观看视频 | 亚洲精品美女久久久 | 综合久久网 | 欧美性护士 | 一区二区三区四区五区在线 | 午夜精品一区二区三区免费 | 99久久精品国 | www天天干com| 夜夜夜夜操| 久久少妇 | 免费av大全 | 欧美一级激情 | 最近中文字幕高清字幕免费mv | 国产精品99久久免费观看 | 久久久精品影视 | av天天色| 欧美日韩综合在线 | 天天操天天摸天天爽 | 99免费在线播放99久久免费 | 五月婷亚洲 | 激情大尺度视频 | 亚洲欧美一区二区三区孕妇写真 | 免费三级黄色片 | 国产一二三四在线视频 | 久久超碰免费 | 欧美色图亚洲图片 | 亚洲无吗av | 六月色丁 | 精品伊人久久久 | 在线亚洲高清视频 | 黄色www免费 | 久草在线免费看视频 | 久久福利小视频 | 欧美aa一级 | 一级免费黄色 | 亚洲午夜久久久久久久久 | 中文字幕亚洲情99在线 | 日韩免费在线视频观看 | 日本精品视频在线 | 亚洲天天在线 | 久久久精品 | 丝袜美腿av | 国产精品成人久久 | 一级黄色片在线免费看 | 国精产品永久999 | 亚洲丝袜一区二区 | 五月婷婷在线观看视频 | 婷婷深爱五月 | www婷婷| 亚洲精品资源在线观看 | av3级在线| 国产女v资源在线观看 | 日韩精品一区二区三区在线视频 | 国产在线视频在线观看 | 久久精品观看 | 亚洲国产精品一区二区久久hs | 天堂黄色片 | 草久久精品 | 天天天天射 | 涩涩成人在线 | 欧美日韩视频一区二区 | 国产精品久久久久毛片大屁完整版 | 国产一区播放 | 日韩有码中文字幕在线 | 亚洲理论在线观看 | 国产99在线播放 | 免费男女羞羞的视频网站中文字幕 | 久久99日韩 | 一区二区视频在线免费观看 | av成人在线电影 | 亚洲va男人天堂 | 久久久亚洲精品 | 狠狠的操狠狠的干 | japanese黑人亚洲人4k | 亚洲高清免费在线 | 精品视频免费在线 | av动态图片 | 深爱激情五月网 | 国产不卡高清 | 久久精品一区二区 | 九色免费视频 | 国产免费成人 | 在线91观看 | 天天色影院 | 成人永久视频 | 久久深夜福利免费观看 | 波多野结衣久久资源 | 91亚·色 | www.伊人网.com | 美女av电影| 在线免费观看视频你懂的 | 午夜精选视频 | 婷婷在线免费观看 | 欧美日韩精品在线播放 | 国产在线国偷精品产拍 | 99re亚洲国产精品 | 色欲综合视频天天天 | 国产精品美女久久久久久久 | 最近中文字幕免费av | 一级α片免费看 | 黄色小说视频在线 | 最近中文字幕完整视频高清1 | 久草在线高清视频 | 91久久精品一区二区二区 | 丁香九月激情 | 麻花传媒mv免费观看 | 久久99热国产 | 在线观看中文字幕 | 99精品视频免费在线观看 | 国产首页 | 狠狠干在线播放 | 欧美日韩在线免费视频 | 女人高潮一级片 | 国产视| 69精品在线 | 一区二区三区在线看 | 免费人成网ww44kk44 | 免费在线观看av网站 | 免费在线国产 | 久久视频网 | 国产精品久久久久久一二三四五 | 人人爽人人做 | 91久久黄色 | 超碰在线97国产 | 亚洲国产日韩在线 | 91精品在线播放 | 天天干,夜夜操 | 国产精品日韩 | 日韩av福利在线 | 天天色天天干天天 | 中文字幕免费看 | 国产精品久久久久久一二三四五 | 国产一及片 | 午夜av不卡 | 国产在线观看你懂得 | 最新日韩视频 | 日韩欧美专区 | 中文字幕欧美激情 | 国产精品18久久久久久久 | 深爱婷婷久久综合 | 国产视频一区在线免费观看 | 天天爱天天操天天爽 | 在线观看黄色免费视频 | 亚洲精品av中文字幕在线在线 | a视频免费在线观看 | 精品一区二区三区香蕉蜜桃 | 开心婷婷色 | 91片黄在线观看动漫 | 91看片网址| 日韩久久精品一区二区 | 香蕉视频在线免费 | 久久久久久在线观看 | 丁香午夜婷婷 | 深夜国产在线 | 麻豆免费在线播放 | 亚洲永久精品在线 | 偷拍精偷拍精品欧洲亚洲网站 | 国产综合片 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 久久不射电影院 | 亚洲精品一区二区三区高潮 | 亚洲女欲精品久久久久久久18 | 欧美成人精品三级在线观看播放 | 九九九热视频 | 国产免费三级在线观看 | 欧美成人中文字幕 | 黄色成年 | 色婷婷激情四射 | 久久精品官网 | 精品国产一区二区三区四区在线观看 | 欧美日韩中文在线 | 黄色成品视频 | 搡bbbb搡bbb视频 | www成人精品 | 日韩欧美视频二区 | 久草视频99 | 久久综合色一综合色88 | 亚洲视屏一区 | 成人在线观看免费视频 | 色搞搞| 日韩系列 | 97久久久免费福利网址 | 日韩精品不卡在线 | 久久网页 | 成人小视频免费在线观看 | 久久免费看片 | 国产亚洲欧美在线视频 | 激情五月六月婷婷 | 精品久久一二三区 | 国产精品久久久久久久久久白浆 | 久久久黄视频 | 亚洲精品美女在线观看播放 | 久久精品一区 | 成人羞羞免费 | 欧美色精品天天在线观看视频 | 免费观看日韩 | 精品国产一区二区三区久久影院 | 黄色a在线| 五月天狠狠操 | 国产精品精品国产 | 亚洲精品中文在线观看 | 天天婷婷 | 国产99久久久精品 | 国产成人精品免高潮在线观看 | 中文字幕精品一区久久久久 | 天天综合在线观看 | av在线免费观看黄 | 国产成人一区三区 | 精品99久久| 日韩偷拍精品 | 精品一区二区在线观看 | 亚洲一区尤物 | 黄色大片入口 | 国产精品原创在线 | 国产在线观看xxx | 一区二区三区四区精品 | 久久露脸国产精品 | 日韩成人xxxx | 日本激情视频中文字幕 | 91热视频在线观看 | 欧美精品中文在线免费观看 |