当前位置:首页 > 服务端 > netty 请求 转发http

netty 请求 转发http

https://netty.io/4.1/xref/io/netty/example/proxy/package-summary.html

https://netty.io/4.1/xref/io/netty/example/proxy/HexDumpProxy.html

package com.test;

import io.netty.channel.ChannelInitializer;

import io.netty.channel.socket.SocketChannel;

import io.netty.handler.logging.LogLevel;

import io.netty.handler.logging.LoggingHandler;

public class HexDumpProxyInitializer extends ChannelInitializer {

private final String remoteHost;

private final int remotePort;

public HexDumpProxyInitializer(String remoteHost, int remotePort) {

this.remoteHost = remoteHost;

this.remotePort = remotePort;

}

@Override

public void initChannel(SocketChannel ch) {

// 获取当前类名;

System.out.println(this.getClass());

ch.pipeline().addLast(

new LoggingHandler(LogLevel.INFO),

new HexDumpProxyInitializer(remoteHost, remotePort)

);

}

}

package com.test;

import io.netty.bootstrap.ServerBootstrap;

import io.netty.channel.ChannelOption;

import io.netty.channel.EventLoopGroup;

import io.netty.channel.nio.NioEventLoopGroup;

import io.netty.channel.socket.nio.NioServerSocketChannel;

import io.netty.handler.logging.LogLevel;

import io.netty.handler.logging.LoggingHandler;

public class HexDumpProxy {

static final int LOCAL_PORT = Integer.parseInt(System.getProperty("localPort", "8443"));

static final String REMOTE_HOST = System.getProperty("remoteHost", "11.21.1.2");

static final int REMOTE_PORT = Integer.parseInt(System.getProperty("remotePort", "50000"));

public static void main(String[] args) throws Exception {

System.err.println("Proxying *:" + LOCAL_PORT + " to " + REMOTE_HOST + ":" + REMOTE_PORT + "...");

// Configure the bootstrap

EventLoopGroup bossGroup = new NioEventLoopGroup(1);

EventLoopGroup workerGroup = new NioEventLoopGroup();

try {

ServerBootstrap b = new ServerBootstrap();

b.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class)

.handler(new LoggingHandler(LogLevel.INFO))

.childHandler(new HexDumpProxyInitializer(REMOTE_HOST, REMOTE_PORT))

.childOption(ChannelOption.AUTO_READ, false)

.bind(LOCAL_PORT).sync().channel().closeFuture().sync();

} finally {

bossGroup.shutdownGracefully();

workerGroup.shutdownGracefully();

}

}

}

作者:13775689191
来源链接:https://blog.csdn.net/weixin_34180753/article/details/112944782


版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/server/68307.html

标签: NettyHTTP
分享给朋友: