MIRAI BOTNET
요새 MIRAI BOTNET이 한창 말이 많아서
과연 내 IoT 제품은 안전할까? 걱정되시는 분들이 많으실 것 같습니다.
그런데 벌써 MIRAI 소스코드가 다 공개되었기 때문에
MIRAI가 실제로 IoT 기기 공격을 어떻게 하는건지 분석했고
주요 부분만 간추려서 정리하였습니다.
일단 바쁘신 분들을 위해 결론만 적어보자면
MIRAI BOTNET에 취약한가?
2. ID/PW가 추측하기 쉽다.
이러면 기본적으로 MIRAI BOTNET 에 취약하다 볼 수 있습니다.
반대로 1, 2 둘 중 하나만 만족하지 않아도 MIRAI BOTNET에 취약하지 않습니다.
그러나 금방 변형이 등장할 것 이므로.....
해결책은?
1. 최대한 (특히 쉘을 제공하는) 포트를 열지 않는다.
2. 아이디 / 패스워드를 어렵고 길게 만든다.
정도가 되겠네요.
MIRAI -> IoT 기기 공격 분석입니다.
1. Injection
공격 방식은 아이디/패스워드 테이블에서 랜덤하게 뽑아서 대입해 보는 것으로,Burpsuite 의 Intruder로 따지자면 Pitchfork 형태가 되겠습니다.
이 Parameter는 add_auth_entry("아이디", "패스워드", "가중치") 로 설정하는데,
가중치가 높을수록 공격시 랜덤으로 뽑힐 가능성이 높아집니다.
가장 가중치를 높게( 10 ) 설정 한 부분의 난독화를 풀면
add_auth_entry("root", "xc3511", 10) 입니다.
아이디가 root이면서 패스워드가 xc3511 인 IoT 기기가 특히 많나 보네요.
2. Port
보시면 Packet Header 를 설정하는데, dest 는 23번 (Telnet) 포트로 고정하고,
src는 1024 이하에서 랜덤으로 설정합니다.
이 부분이 중요합니다. MIRAI BOTNET은 23번 포트만 스캐닝 합니다.
1, 2 번이 끝나고 3번부터는 계속 루프를 돌면서 스캐닝을 합니다.
3. IP
IP는 랜덤하게 가져옵니다.
다만 정말 마구잡이로 랜덤하게 설정하는 것은 아닙니다.
아래처럼,
Class별로 IP처럼 생긴 숫자만 뽑아서 랜덤하게 만듭니다.
4. Scan
이제 Syn Raw Packet을 만들어 쏘고, Syn +Ack 패킷 받는 걸 계속합니다.
방식은 하나씩 시도 해보는게 아니라
커넥션을 128개까지 만들어서 syn 패킷을 보내놓고,
한꺼번에 처리하는 방식입니다.
5. Attack
Connection이 성립하면 공격을 하는데,
이 부분을 BruteForce라고 부르기가... 좀 애매합니다.
왜냐하면 62개 정도 밖에 안되는 ID / PW 셋을
모두 다 시도 해보는 것도 아니고
아래처럼 가중치에 따라 랜덤하게 뽑아서 시도 해보기 때문입니다.
다만 Connection 이 살아있다면, 10번 정도 더 시도 해보긴 합니다.....
마치며...
일단 오늘 MIRAI Botnet 공격( MIRAI -> IoT )의 실체를 파헤쳐 보았는데요.
소스 코드를 보면 복잡하고 어려운 공격이라기 보다
최대한 빠르게 취약한 기기들을 장악하려는 제작자의 의도를 알 수 있습니다.
성공 후 감염은 어떻게 시키는 건지
CNC 서버와 통신은 어떻게 하는건지 등등
더 볼만한 부분이 많습니다.
MIRAI의 소스는 다음 GitHub주소 에서 보실 수 있습니다.
https://github.com/jgamblin/Mirai-Source-Code
감사합니다.
미라이 봇넷 난독화를 어떻게 풀었는지 알수있을까요?
답글삭제일반적으로 난독화 푸는 식으로 코드를 따라가면서 풀면 됩니다. 인터넷 찾아보시면 풀어서 주석으로 남겨둔게 올라와 있을겁니다.
삭제깔끔하게 정리 잘해주셨네요!! 감사합니다
답글삭제감사합니다~!
삭제g혹시 저 깃허브에서 어떤 코드들을 보신건지 알려주실 수 있으신가요?
답글삭제설명 감사합니다!! 그런데 혹시 깃허브의 코드들 중에서도 어떤 파일을 보신건지 알려주실 수 있으신가요?
답글삭제너무 늦었네요 :( 당시 공식 코드는 하나밖에 없었던 걸로 기억합니다.
삭제