欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java Netty HTTP服務(wù)實(shí)現(xiàn)過(guò)程解析

 更新時(shí)間:2020年08月13日 09:31:36   作者:猿天地  
這篇文章主要介紹了Java Netty HTTP服務(wù)實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

超文本傳輸協(xié)議(HTTP,HyperText Transfer Protocol)是互聯(lián)網(wǎng)上應(yīng)用最為廣泛的一種網(wǎng)絡(luò)協(xié)議。

在后端開(kāi)發(fā)中接觸HTTP協(xié)議的比較多,目前大部分都是基于Servlet容器實(shí)現(xiàn)的Http服務(wù),往往有一些核心子系統(tǒng)對(duì)性能的要求非常高,這個(gè)時(shí)候我們可以考慮采用NIO的網(wǎng)絡(luò)模型來(lái)實(shí)現(xiàn)HTTP服務(wù),以此提高性能和吞吐量,Netty除了開(kāi)發(fā)網(wǎng)絡(luò)應(yīng)用非常方便,還內(nèi)置了HTTP相關(guān)的編解碼器,讓用戶可以很方便的開(kāi)發(fā)出高性能的HTTP協(xié)議的服務(wù),Spring Webflux默認(rèn)是使用的Netty。

接下來(lái)我們簡(jiǎn)單的介紹下如何使用Netty來(lái)構(gòu)建一個(gè)簡(jiǎn)單的Http服務(wù)

創(chuàng)建一個(gè)NettyHttpServer來(lái)啟動(dòng)服務(wù)

public static void main(String[] args) {
  int port = 2222;
  new NettyHttpServer().run(port);
}

public void run(int port) {
  EventLoopGroup bossGroup = new NioEventLoopGroup();
  EventLoopGroup workerGroup = new NioEventLoopGroup();
  ServerBootstrap bootstrap = new ServerBootstrap();
  bootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class)
      .childHandler(new ChannelInitializer<SocketChannel>() {
        @Override
        public void initChannel(SocketChannel ch) throws Exception {
            ch.pipeline().addLast(
                new HttpResponseEncoder(),
                new HttpRequestDecoder(),
                new NettyHttpServerHandler());
        }
        }).option(ChannelOption.SO_BACKLOG, 128)
        .childOption(ChannelOption.SO_KEEPALIVE, true);
  try {
    ChannelFuture f = bootstrap.bind(port).sync();
    f.channel().closeFuture().sync();
  } catch (InterruptedException e) {
    e.printStackTrace();
  } finally {
    workerGroup.shutdownGracefully();
    bossGroup.shutdownGracefully();
  }
}

需要關(guān)注的是下面的這行代碼:

ch.pipeline().addLast(
new HttpResponseEncoder(),
new HttpRequestDecoder(),
new NettyHttpServerHandler());

HttpResponseEncoder: 服務(wù)端往客戶端發(fā)送數(shù)據(jù)的行為是Response,所以這邊要使用HttpResponseEncoder將數(shù)據(jù)進(jìn)行編碼操作

HttpRequestDecoder:服務(wù)端接收到數(shù)據(jù)的行為是Request,所以要使用HttpRequestDecoder進(jìn)行解碼操作

NettyHttpServerHandler:自定義的數(shù)據(jù)處理類

public class NettyHttpServerHandler extends ChannelInboundHandlerAdapter {

public class NettyHttpServerHandler extends ChannelInboundHandlerAdapter {

  @Override
  public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {  
    FullHttpResponse response = new DefaultFullHttpResponse(
        HttpVersion.HTTP_1_1, 
        HttpResponseStatus.OK,
        Unpooled.wrappedBuffer("歡迎來(lái)到猿天地".getBytes("utf-8")));
    response.headers().set(Names.CONTENT_TYPE, "text/plain;charset=UTF-8");
    response.headers().set(Names.CONTENT_LENGTH, response.content().readableBytes());
    response.headers().set(Names.CONNECTION, Values.KEEP_ALIVE);
    ctx.write(response);
    ctx.flush();
  }

  @Override
  public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {
    ctx.flush();
  }

  @Override
  public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
    ctx.close();
    cause.printStackTrace();
  }

}

通過(guò)DefaultFullHttpResponse構(gòu)建了返回的對(duì)象,設(shè)置了HTTP版本,返回的狀態(tài)碼,返回的內(nèi)容。

返回的響應(yīng)頭通過(guò)response.headers().set()進(jìn)行設(shè)置。

到此為止,一個(gè)簡(jiǎn)單的HTTP服務(wù)就實(shí)現(xiàn)好了,我們啟動(dòng)服務(wù),在瀏覽器中輸入http://localhost:2222/ 就可以看到頁(yè)面中顯示的內(nèi)容是:歡迎來(lái)到猿天地

上面演示的是一個(gè)典型的請(qǐng)求響應(yīng)模式,一般我們開(kāi)發(fā)接口的時(shí)候通常都是需要根據(jù)請(qǐng)求的參數(shù)進(jìn)行對(duì)應(yīng)的數(shù)據(jù)返回,如何在Netty中獲取請(qǐng)求的參數(shù)呢?

channelRead方法中的msg參數(shù)就是請(qǐng)求信息,通過(guò)msg可以獲取到請(qǐng)求的所有信息,有請(qǐng)求頭信息(包括請(qǐng)求的地址,GET請(qǐng)求的參數(shù)),請(qǐng)求體(POST請(qǐng)求的數(shù)據(jù))。

下面已GET請(qǐng)求的方式來(lái)獲取請(qǐng)求的參數(shù)信息,代碼如下:

if (msg instanceof HttpRequest) {
    DefaultHttpRequest request = (DefaultHttpRequest) msg;
    System.out.println("URI:" + request.getUri());
    System.err.println(msg);
}
if (msg instanceof HttpContent) {
    LastHttpContent httpContent = (LastHttpContent) msg;
    ByteBuf byteData = httpContent.content();
    if (byteData instanceof EmptyByteBuf) {
      System.out.println("Content:無(wú)數(shù)據(jù)");
    } else {
      String content = new String(ByteUtils.objectToByte(byteData));
      System.out.println("Content:" + content);
    }
}

重啟服務(wù),訪問(wèn)地址加上參數(shù)進(jìn)行訪問(wèn):http://localhost:2222/?name=yjh

可以看到控制臺(tái)輸出的內(nèi)容就是一個(gè)完整的HTTP請(qǐng)求包含的信息:

URI:/?name=yjh
DefaultHttpRequest(decodeResult: success, version: HTTP/1.1)
GET /?name=yjh HTTP/1.1
Host: localhost:2222
Connection: keep-alive
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.186 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9
Cookie: _ga=GA1.1.939107719.1520393952; JSESSIONID=EE205236911D5BBA145E3021DB472D90
Content:無(wú)數(shù)據(jù)

本文只是簡(jiǎn)單的介紹了如何在Netty中去實(shí)現(xiàn)HTTP服務(wù),如果想要做成Spring MVC這樣的框架那后面的路還很長(zhǎng),請(qǐng)求響應(yīng)Netty內(nèi)置了編解碼器,還是有很多工作需要自己去做的。比如參數(shù)的獲取,請(qǐng)求的路由,參數(shù)映射成對(duì)象等….

源碼參考:https://github.com/yinjihuan/netty-im

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring Boot集成Swagger接口分類與各元素排序問(wèn)題

    Spring Boot集成Swagger接口分類與各元素排序問(wèn)題

    這篇文章主要介紹了Spring Boot集成Swagger接口分類與各元素排序問(wèn)題,首先我們需要對(duì)Swagger中的接口也就是以Controller 層作為第一級(jí)梯度進(jìn)行組織的,Controller在我們實(shí)際開(kāi)發(fā)中,與其他具體接口之間是存在一對(duì)多的關(guān)系,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-10-10
  • java算法之靜態(tài)內(nèi)部類實(shí)現(xiàn)雪花算法

    java算法之靜態(tài)內(nèi)部類實(shí)現(xiàn)雪花算法

    這篇文章主要介紹了java算法之靜態(tài)內(nèi)部類實(shí)現(xiàn)雪花算法,對(duì)算法感興趣的同學(xué),一定要看一下
    2021-05-05
  • Java Metrics系統(tǒng)性能監(jiān)控工具的使用詳解

    Java Metrics系統(tǒng)性能監(jiān)控工具的使用詳解

    Metrics是一個(gè)Java庫(kù),可以對(duì)系統(tǒng)進(jìn)行監(jiān)控,統(tǒng)計(jì)一些系統(tǒng)的性能指標(biāo)。本文就來(lái)和大家詳細(xì)聊聊這個(gè)工具的具體使用,希望對(duì)大家有所幫助
    2022-11-11
  • Java發(fā)送郵件javax.mail的實(shí)現(xiàn)方法

    Java發(fā)送郵件javax.mail的實(shí)現(xiàn)方法

    這篇文章主要為大家介紹了Java發(fā)送郵件javax.mail的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,代碼都有詳細(xì)的注釋,感興趣的小伙伴們可以參考一下
    2016-01-01
  • SpringBoot框架如何管理Xml和CSV

    SpringBoot框架如何管理Xml和CSV

    XML是可擴(kuò)展標(biāo)記語(yǔ)言,是一種用于標(biāo)記電子文件使其具有結(jié)構(gòu)性的標(biāo)記語(yǔ)言。CSV是一種通用的、相對(duì)簡(jiǎn)單的文件格式,通常被用在大數(shù)據(jù)領(lǐng)域,進(jìn)行大規(guī)模的數(shù)據(jù)搬運(yùn)操作,本文將介紹SpringBoot框架如何管理Xml和CSV
    2021-06-06
  • java return用法實(shí)例詳解

    java return用法實(shí)例詳解

    在本篇文章里小編給大家整理的是關(guān)于java return用法以及相關(guān)知識(shí)點(diǎn)總結(jié),需要的朋友們參考下。
    2019-08-08
  • SpringBoot 中 AutoConfiguration的使用方法

    SpringBoot 中 AutoConfiguration的使用方法

    這篇文章主要介紹了SpringBoot 中 AutoConfiguration的使用方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • Springboot和Jpa實(shí)現(xiàn)學(xué)生CRUD操作代碼實(shí)例

    Springboot和Jpa實(shí)現(xiàn)學(xué)生CRUD操作代碼實(shí)例

    這篇文章主要介紹了Springboot和Jpa實(shí)現(xiàn)學(xué)生CRUD操作代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • hbase訪問(wèn)方式之java api

    hbase訪問(wèn)方式之java api

    這篇文章主要介紹了hbase訪問(wèn)方式之java api,需要的朋友可以參考下
    2017-09-09
  • Springboot解決no main manifest attribute錯(cuò)誤

    Springboot解決no main manifest attribute錯(cuò)誤

    在開(kāi)發(fā)Springboot項(xiàng)目時(shí),使用java -jar命令運(yùn)行jar包可能出現(xiàn)no main manifest attribute錯(cuò)誤,本文就來(lái)介紹一下該錯(cuò)誤的解決方法,感興趣的可以了解一下
    2024-09-09

最新評(píng)論