ALPN协议

本文介绍了ALPN协议的基础概念及其在TLS扩展中的作用。ALPN允许客户端和服务端在建立安全连接时协商使用哪种应用层协议,如HTTP/2或SPDY等。文章还详细介绍了两种ALPN实现方式:Jetty和OpenSSL。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

协议介绍

  ALPN (Application Layer Protocol Negotiation)是TLS的扩展,允许在安全连接的基础上进行应用层协议的协商。ALPN支持任意应用层协议的协商,目前应用最多是HTTP2的协商。在2016年,ALPN已经完全替代NPN了。

  ALPN allows the application layer to negotiate which protocol to use over the secure connection. Any protocol can be negotiated by ALPN within a TLS connection. The protocols that are most commonly negotiated are HTTP/2 (for browsers that support it) and, historically, SPDY. The ALPN implementation is therefore not HTTP/2 or SPDY specific in any way.

               这里写图片描述

协商原理

  在TLS的Say Hello阶段增加应用层协议的协商,如下图所示:
这里写图片描述

ALPN实现

实现一:Jetty

  Jetty以独立JAR包形式提供了ALPN实现,但是需要依赖OpenJDK 7或者OpenJDK 8,具体配置和API使用请参考这里

实现二:OpenSSL

  需要将版本升级到1.0.2 以上,具体查看这里
  
参考:

  1. https://www.eclipse.org/jetty/documentation/9.3.x/alpn-chapter.html
  2. https://eggggger.xyz/2016/10/16/HTTP2/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值