타이밍어택 개념
Timing Attack - 타이밍어택이란 어떤 공격인가?
프로그래밍을 할 때 같은 문자열인지를 알아내기 위해 is_equal() 함수를 쓴다고 하자.
어떤 입력값이 "yotaiji" 라는 문자열과 똑같은지 비교를 한다고 하자. 그러면 처음엔 y, 그 다음엔 o, 그 다음엔 t... 이와 같은 순서로 첫번째 문자부터 하나씩 비교를 해간다.
만일 한 문자를 비교하는데 걸리는 시간이 0.001ms라고 가정할때!
만약 내가 "yaaaaaa" 라는 문자열을 넣었다면 두번째 문자를 비교할 때 다르다는 걸 알게 되고 컴퓨터는 return false를 할 것이다. 걸린 시간 0.002ms(y, a 까지 비교 시간합)
그 다음엔 "yoaaaaa" 를 넣어본다. 그러면 세번째 문자에서 false를 보여줄 것이다.
걸린 시간 0.003ms(y, o, a 까지 비교 시간합)
여기서 일치문자가 많을수록 함수 실행 속도가 조금 차이가 나게된다. 물론 쉽게 측정은 안되지만 어느정도 시도를 하다보면 마이크로초, 또는 나노초 단위로 문자열이 다른지를 비교하는 시간이 차이가 난다.
이걸로 해커들이 중요한 키 값이나 비밀번호 등을 알아낼 수 있다고 한다. 이를 해결하는 가장 간단한 방법은 앞의 문자에서 다르다는 걸 깨달아도 무조건 끝까지 비교하는 코드를 새로 작성하면 언제나 수행시간이 거의 같으므로 타이밍 어택을 피할 수 있다.
PHP에서는 버전 5.6부터 hash_equals() 라는 대책함수가 지원되었다.
댓글 1개
따왕666
2년 전
신통한 생각입니다.
게시판 목록
토크
개발과 관련된 어떤 얘기도 괜찮습니다.
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 3361 |
|
9년 전 | 885 | |
| 3360 | 9년 전 | 1222 | ||
| 3359 |
kiplayer
|
9년 전 | 990 | |
| 3358 | 9년 전 | 853 | ||
| 3357 |
커네드커네드
|
9년 전 | 989 | |
| 3356 |
|
9년 전 | 1606 | |
| 3355 | 9년 전 | 1343 | ||
| 3354 | 9년 전 | 1130 | ||
| 3353 | 9년 전 | 1215 | ||
| 3352 | 9년 전 | 1879 | ||
| 3351 | 9년 전 | 3619 | ||
| 3350 | 9년 전 | 1463 | ||
| 3349 | 9년 전 | 1496 | ||
| 3348 | 9년 전 | 1282 | ||
| 3347 |
|
9년 전 | 1309 | |
| 3346 |
|
10년 전 | 1322 | |
| 3345 | 10년 전 | 2592 | ||
| 3344 | 10년 전 | 1268 | ||
| 3343 |
Tosea
|
10년 전 | 2789 | |
| 3342 | 10년 전 | 1173 | ||
| 3341 |
비긴어게인
|
10년 전 | 1672 | |
| 3340 | 10년 전 | 1895 | ||
| 3339 | 10년 전 | 2479 | ||
| 3338 | 10년 전 | 1412 | ||
| 3337 | 10년 전 | 2166 | ||
| 3336 | 10년 전 | 2295 | ||
| 3335 | 10년 전 | 2273 | ||
| 3334 | 10년 전 | 2140 | ||
| 3333 | 10년 전 | 2292 | ||
| 3332 | 10년 전 | 1957 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기