Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Безопасность соединения
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
REDMADROBOT
September 11, 2018
5.5k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Безопасность соединения
REDMADROBOT
September 11, 2018
More Decks by REDMADROBOT
See All by REDMADROBOT
rn.pdf
redmadrobot
0
5.5k
Как внедрить Siri в приложение и помочь Apple сделать её полезнее
redmadrobot
0
5.7k
Featured
See All Featured
Between Models and Reality
mayunak
4
340
Fireside Chat
paigeccino
42
4k
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
840
A Tale of Four Properties
chriscoyier
163
24k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.5k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
170
jQuery: Nuts, Bolts and Bling
dougneiner
66
8.5k
Navigating Weather and Climate Data
rabernat
0
220
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
460
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.7k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
1.1k
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
150
Transcript
Безопасность соединения Емельяненков Александр 07/09/2018
[email protected]
Агенда - Изобретаем TLS - MITM over TLS - SSL
Pinning 01
02
02 Самодержавие — !
02
02
02
02
02
02
АСИММЕТРИЧНОЕ Шифрование 03 CИММЕТРИЧНОЕ
АСИММЕТРИЧНОЕ Шифрование 03 Вот каким ключом шифровали, таким и расшифровывайте!
CИММЕТРИЧНОЕ
- Открытый ключ для шифрования АСИММЕТРИЧНОЕ Шифрование 03 Вот каким
ключом шифровали, таким и расшифровывайте! CИММЕТРИЧНОЕ
- Открытый ключ для шифрования - Закрытый ключ для расшифровки
АСИММЕТРИЧНОЕ Шифрование 03 Вот каким ключом шифровали, таким и расшифровывайте! CИММЕТРИЧНОЕ
04
04
04
04
04
04 ? ?
05
05
05
06
06
06
06 ?
06 ?
07
07
07
07
07
07
07
07
Сертификат X.509 - Открытый ключ - Сведения о владельце -
Цифровая подпись 08
Аутентификация ключа 09
Аутентификация ключа 09
Аутентификация ключа 09
Аутентификация ключа 09
Аутентификация ключа 10
Аутентификация ключа 10
Аутентификация ключа 10
11
11
11 ?
Цепочка доверия 12
Цепочка доверия 12
Цепочка доверия 12
13 Цепочка доверия
13 Цепочка доверия
13 Цепочка доверия
Промежуточный итог 14
15 TLS
15 TLS
15 TLS Hello
15 TLS Hello Certificate Exchange
15 TLS Hello Certificate Exchange
15 TLS Hello Certificate Exchange
15 TLS Hello Certificate Exchange
15 TLS Hello Certificate Exchange
15 TLS Hello Certificate Exchange Key exchange
Ах, эти протоколы - SSL - HTTPS - TLS 16
SSL, TLS, HTTPS - Шифрование - Аутентификация - Проверка целостности
17
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
18 MITM over TLS
19
19
20 Пиннинг
20 Пиннинг
20 Пиннинг
20 Пиннинг
URLSession 21 func urlSession( _ session: URLSession, didReceive challenge: URLAuthenticationChallenge,
completionHandler: @escaping (URLSession.AuthChallengeDisposition,URLCredential?) -> Void) { let serverTrust: SecTrust = challenge.protectionSpace.serverTrust ... completionHandler(.cancelAuthenticationChallenge, nil) }
Alamofire 22 public static func certificates( in bundle: Bundle =
Bundle.main) -> [SecCertificate] public static func publicKeys( in bundle: Bundle = Bundle.main) -> [SecKey] let serverTrustPolicy = ServerTrustPolicy.pinCertificates( certificates: ServerTrustPolicy.certificates(), validateCertificateChain: true, validateHost: true)
Когда не надо пинниться - Не контролируем сервер - Нет
чувствительных данных 23
Виды пиннинга 24 на какой сертификат пиннимся
Виды пиннинга 24 на какой сертификат пиннимся
- fingerprint - открытый ключ Виды пиннинга 24 на какой
сертификат пиннимся на что пиннимся в сертификате
Пиннинг на fingerprint 25
Пиннинг на fingerprint 25
Пиннинг на fingerprint 25
Пиннинг на fingerprint 25
Пиннинг на fingerprint 25
Пиннинг на fingerprint 25
26 Пиннинг на открытый ключ
26 Пиннинг на открытый ключ
26 Пиннинг на открытый ключ
26 Пиннинг на открытый ключ
Пиннинг - Плюсы: - перевыпуск сертификата - отказ от цепочки
доверия - можно перейти к другому CA - Минусы: - дольше храним/не меняем ключ 27 на открытый ключ конечного сертификата
Итог - Декабристы, TLS и цепочка доверия - MITM over
TLS - SSL Pinning - Когда и как пинниться 28
Литература - Performing manual server trust authentication - Ключи, шифры,
сообщения: как работает TLS 29