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
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
2
220
Git: the NoSQL Database
bkeepers
PRO
432
67k
Six Lessons from altMBA
skipperchong
29
4.3k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
430
Leo the Paperboy
mayatellez
7
1.8k
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
140
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
250
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
390
Rebuilding a faster, lazier Slack
samanthasiow
85
9.5k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
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