Uygulama Katmanı Protokol Anlaşması - Application-Layer Protocol Negotiation - Wikipedia

Uygulama katmanı Protokol Müzakeresi (ALPN) bir taşıma katmanı Güvenliği (TLS) uzantısı, uygulama katmanının hangisinin protokol Ek gidiş-dönüşleri önleyecek ve uygulama katmanı protokollerinden bağımsız bir şekilde güvenli bir bağlantı üzerinden gerçekleştirilmelidir. Güvenli tarafından gerekli HTTP / 2 HTTP / 1.x'e kıyasla web sayfalarının sıkıştırmasını iyileştiren ve gecikmelerini azaltan bağlantılar. ALPN ve HTTP / 2 standartları, şu anda geri çekildiğinde Google tarafından yapılan geliştirme çalışmalarından ortaya çıktı. SPDY protokol.

Destek

ALPN şu kitaplıklar tarafından desteklenmektedir:

  • GnuTLS Mayıs 2013'te yayınlanan 3.2.0 sürümünden beri[1]
  • MatrixSSL 3.7.1 sürümünün Aralık 2014'te piyasaya sürülmesinden bu yana[2]
  • Ağ Güvenliği Hizmetleri Nisan 2014'te piyasaya sürülen 3.15.5 sürümünden beri[3]
  • OpenSSL 1.0.2 sürümü Ocak 2015'te piyasaya sürüldüğünden beri[4]
  • LibreSSL Ocak 2015'te yayınlanan 2.1.3 sürümünden beri[5]
  • mbed TLS (önceden PolarSSL) Nisan 2014'te piyasaya sürülen 1.3.6 sürümünden beri[6]
  • SChannel 8.1 / 2012 R2'den beri
  • s2n Haziran 2015'teki ilk halka açıklanmasından bu yana.
  • wolfSSL (eski adıyla CyaSSL) 3.7.0 sürümünün Ekim 2015'te piyasaya sürülmesinden bu yana[7]
  • Git (standart kitaplık crypto / tls paketinde) Aralık 2014'te yayınlanan sürüm 1.4'ten beri[8]
  • picotls[9]
  • JSSE içinde Java JDK 9 Eylül 2017'de piyasaya sürüldüğünden beri,[10] Nisan 2020'de piyasaya sürülen JDK 8'e geri aktarıldı[11]
  • BearSSL 0.3 sürümünden beri[12]
  • Win32 SSPI Windows 8.1 ve Windows Server 2012 R2, 18 Ekim 2013'te piyasaya sürüldüğünden beri[13]

Tarih

11 Temmuz 2014'te ALPN şu şekilde yayınlandı: RFC  7301. ALPN, NPN'nin yerini alıyor[14]

TLS Yanlış Başlatma devre dışı bırakıldı Google Chrome 20'den (2012) itibaren, önceki sürümlere sahip web siteleri hariç Sonraki Protokol Görüşmesi (NPN) uzantı.[15]

Misal

ALPN, başlangıçta gönderilen bir TLS uzantısıdır. TLS anlaşması 'Client Hello' ve istemcinin (örneğin web tarayıcısı) desteklediği protokolleri listeler:

    El Sıkışma Türü: İstemci Merhaba (1) Uzunluk: 141 Sürüm: TLS 1.2 (0x0303) Rastgele: dd67b5943e5efd0740519f38071008b59efbd68ab3114587 ... Oturum Kimliği Uzunluk: 0 Şifreleme Paketi Uzunluğu: 10 Şifreleme Paketi (5 süit) Sıkıştırma Yöntemleri Uzunluk: 1 Sıkıştırma Yöntemleri (1 yöntem ) Uzantı Uzunluğu: 90 [diğer uzantılar atlandı] Uzantı: application_layer_protocol_negotiation (len = 14) Tür: application_layer_protocol_negotiation (16) Uzunluk: 14 ALPN Uzantı Uzunluğu: 12 ALPN Protokolü ALPN dizisi uzunluğu: 2 ALPN Sonraki Protokol: h2 ALPN dizi uzunluğu: 8 ALPN Sonraki Protokol: http / 1.1

Web sunucusundan elde edilen 'Sunucu Merhaba' ayrıca ALPN uzantısını da içerecek ve HTTP isteği için hangi protokolün kullanılacağını onaylar:

    El sıkışma tipi: Sunucu Merhaba (2) Uzunluk: 94 Sürüm: TLS 1.2 (0x0303) Rastgele: 44e447964d7e8a7d3b404c4748423f02345241dcc9c7e332 ... Oturum Kimliği Uzunluk: 32 Oturum Kimliği: 7667476d1d698d0a90caa1d9a449be814b89a0b52f470e2d ... Şifreleme Suite: TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (0xc02f) Sıkıştırma Yöntemi: boş (0) Uzantılar Uzunluk: 22 [diğer uzantılar atlandı] Uzantı: application_layer_protocol_negotiation (len = 5) Tür: application_layer_protocol_negotiation (16) Uzunluk: 5 ALPN Uzantı Uzunluğu: 3 ALPN Protokolü ALPN dizisi uzunluğu: 2 ALPN Sonraki Protokol: h2

Referanslar

  1. ^ "gnutls 3.2.0". Arşivlenen orijinal 2016-01-31 tarihinde. Alındı 2015-01-26.
  2. ^ "MatrixSSL - Haberler". 2014-12-04. Arşivlenen orijinal 2015-02-14 tarihinde. Alındı 2015-01-26.
  3. ^ "NSS 3.15.5 sürüm notları". Mozilla Geliştirici Ağı. Mozilla. Alındı 2015-01-26.
  4. ^ "OpenSSL 1.0.2 sürüm notları". OpenSSL Projesi. OpenSSL Projesi. 2015-01-22. Alındı 2015-01-26.
  5. ^ "LibreSSL 2.1.3 yayınlandı". 2015-01-22. Alındı 2015-01-26.
  6. ^ "İndir genel bakış - PolarSSL". 2014-04-11. Alındı 2015-01-26.
  7. ^ "wolfSSL Sürüm Değişiklik Günlüğü". 2015-10-26. Alındı 2015-09-11.
  8. ^ "Go 1.4 Sürüm Notları". 2014-12-10. Alındı 2017-11-28.
  9. ^ "Picotls". GitHub. Alındı 2 Ağustos 2018.
  10. ^ "JEP 244: TLS Uygulama Katmanı Protokolü Görüşme Uzantısı". 2017-08-07. Alındı 2018-08-29.
  11. ^ "Sürüm Notu: TLS Uygulama Katmanı Protokolü Görüşme Uzantısı". 2020-04-30. Alındı 2020-06-11.
  12. ^ "BearSSL - Değişiklik Günlüğü". Alındı 2010-09-08.
  13. ^ "TLS / SSL'deki (Schannel SSP) Yenilikler". Alındı 2020-03-30.
  14. ^ Langley, Adam. "» NPN ve ALPN ". Alındı 2 Nisan 2013.
  15. ^ Langley, Adam. "Yanlış Başlangıç ​​Başarısızlığı (11 Nisan 2012)". Alındı 25 Eylül 2013.

Dış bağlantılar