java netty开发一个http/https代理

http代理数据传播路径:

  1. 客户端将请求发送到代理,代理解析出消息目的地再去请求服务器
  2. 服务器将完整结果返回给代理,代理再将结果返回给客户端
  3. 代理就在两者之间进行中转数据

https消息传播模式:

  1. 客户端将请求的目的地端口明文发送到代理,
  2. 代理解析出服务器host 端口,并连接成功,返回客户端连接成功的标识
  3. 客户端知道代理已经连接成功了,开始将ssl握手之类的加密数据发送给代理
  4. 代理就在服务器客户端之间进行转发数据,他并不知道传输的数据到底是什么,因为是加密的

实现方式:

编程语言:java
框架选择:netty

首先创建一个标准的netty启动


		EventLoopGroup bossGroup = new NioEventLoopGroup();
		EventLoopGroup workGroup = new NioEventLoopGroup();
		try {
			ServerBootstrap b = new ServerBootstrap();
			b.group(bossGroup, workGroup)
					.channel(NioServerSocketChannel.class)
					.option(ChannelOption.SO_BACKLOG, 128)
					.childOption(ChannelOption.SO_KEEPALIVE, true)
					.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 6000)
					.childHandler(new ProxyServiceInit());

			ChannelFuture f = b.bind(PropertiesUtil.getIntProp("start.port")).sync();
			f.channel().closeFuture().sync();
		} finally {
			workGroup.shutdownGracefully();
			bossGroup.shutdownGracefully();
		}



向其中添加这么两个handler,其中HttpServerCodec是netty自带的,HttpService是自己实现的


	@Override
	protected void initChannel(Channel channel) throws Exception {
		ChannelPipeline p = channel.pipeline();
	
		p.addLast("httpcode", new HttpServerCodec());
		p.addLast("httpservice", new HttpService());
	}

HttpServerCodec会将客户端传进来的消息转成httpobject对象,并且是已经被聚合了的http消息,我们在自己写的HttpService中使用


	自定义httpservice 集成simpleinbondhandler

	public class HttpService extends SimpleChannelInboundHandler<HttpObject&
  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值