Simple Network Management Protocol
네트워크 상의 장치로부터 정보를 수집하고 관리
▪ Manager와 Agent 구조
Manager : Agent로부터 정보 제공받음
Agent : 시스템의 정보나 네트워크 정보등을 수집하여 MIB 형태로 보관

polling 방식 (agent쪽 port 오픈)
Event 방식 (서버쪽 port 오픈)

NMS : 네트워크 장비들을 감시/제어하는 관리 시스템
NMS에서 관리하는 방법 =>SNMP 방식/Syslog 방식
SNMP 방식 : MIB에 정의되어 있는 객체들의 OID 값을 전달받아 해당 장비의 상태를 나타냄[참고] https://m.blog.naver.com/yoodh0713/221591628468
✔️ 버전
✔️ 커뮤니티 (Community)
✔️ PDU 타입 (Protocol Data Unit) 타입
Management Information Base
망관리를 위해 사용되는, 체계화된 관리 정보
매니저와 에이전트 간의 인증을 위한 값
== snmp agent로 접속하기 위한 Password 역할을 하는 문자열
snmpwalk: 시스템 정보 확인Usage :
snmpwalk [host] -v[snmp_version]-c[community_name][OID]
snmpwalk 10.0.0.50 -v 2c -c public 1.3.6.1.4.1.77.1.2.25
10.0.0.50 : SNMP 쿼리가 보내질 대상 장치의 IP 주소-v 2c : 사용할 SNMP 프로토콜의 버전-c public : SNMP Community 문자열1.3.6.1.4.1.77.1.2.25 : 계정 정보를 확인하는 OID 값.
라우터 쪽에 161번 포트가 OPEN되어 있는지 확인 => SNMP가 사용중인지 확인
nmap -sU -p 161 10.0.0.200
UDP 스캔 -> sU

커뮤니티 값(장비에 접근하기 위한 값)을 무엇을 쓰고 있을까?


dict.txt = 대입 스크립트 값
./onesixtyone -c dict.txt 10.0.0.200

snmpwalk 10.0.0.50 -v 2c -c public

snmpwalk 10.0.0.200 -v 2c -c public
nmap -sU -p 161 --script snmp-brute 10.0.0.200

usr/local/share/nmap/nselib/data/snmpcommunities.lst 파일에 abc가 없기 때문에 abc는 못찾음 => dictionary bruteforce attack의 단점
위에서 알아낸 community String으로, 커뮤니티에 주어진 권한 파악
CCDU (Cisco Config Download Upload)

10.0.0.200 = 라우터IP / private = community 명
=> C:\Program Files\Cain\CCDU\에 시스코 라우터의 config 파일 저장


10.0.0.200(router)가 shutdown 되도록 config 파일 수정
ping 10.0.0.200 -t
-t: ping 계속 보내기


수정한 config 파일 Upload -> ping 끊김

❗community에 가능한 write 권한은 가능한 설정하지 않는게 좋다.
+) shutdown된 라우터 살리기

enable password & enable secret
둘 다 라우터의 권한 상승을 위한 비밀번호를 설정하는 데 사용
enable password평문으로 저장되며, 설정 파일에 암호가 그대로 표시 (위 코드는 Type 7 암호화 적용)
비교적 보안에 취약
enable secret암호화되어 저장
보안적으로 더 강력하며, 권장되는 방식

service password-encryption 설정
: 패스워드 암호화

5 : MD5, Hash
7 : 비즈네르

쉽게 복호화 가능



Charset : 대입해볼 문자열
Keyspace : 대입해볼 문자의 조합의 수
password 해킹 완료✔️
=> telnet 접속했을때 나오는 첫번째 pw (복호화 하면 cisco)

telnet 10.0.0.200

enable : 사용자모드에서 관리자모드로 전환 (config 수정 가능)
두번째 pw == 아까 secret password crack으로 얻어냈던 pw : abc