리눅스상에서 패킷을 바로 보내는 방법이 있을까요?
글쓴이: gnoygnas / 작성시간: 화, 2006/02/07 - 6:04오후
이더리얼과 TCP DUMP로 패킷을 캡춰한후 아래와 같이 BigEndian 방식으로 버퍼를 만들어 놓았습니다.
버퍼안에는 이더넷, TCP/IP 등의 모든 정보를 넣어두었습니다.
목적은 TCP를 사용해서 Syn, Syn+Ack, ACK의 3way 핸드세이킹을 제대로 하는지 검증해보고 싶어서 입니다.
클라이언트에서 Syn을 보내면 서버에서 Syn+Ack, 다시 클라이언트에서 Ack를 보내는 프로그램을 짜려고 하는데 리눅스에서 바로 하단의 함수를 건드려 보낼 수 있는지 궁금합니다.
도움 주시면 고맙겠네요..^^
char tcp_syn_buf[74]={ 0xd0, 0x00, 0xf1, 0xca, 0x21, 0x26, 0x0c, 0x00, 0x25, 0x29, 0x21, 0x1e, 0x00, 0x08, 0x00, 0x45, 0x3c, 0x00, 0xbc, 0xd3, 0x00, 0x40, 0x06, 0x40, 0xec, 0xe1, 0x16, 0x01, 0xa8, 0xc0, 0x63, 0x01, 0xa8, 0xc0, 0x1b, 0x04, 0x24, 0x21, 0x3a, 0xef, 0x72, 0xb9, 0x00, 0x00, 0x00, 0x00, 0x02, 0xa0, 0xd0, 0x16, 0x0f, 0xa1, 0x00, 0x00, 0xb4, 0x05, 0x04, 0x02, 0x02, 0x04, 0x00, 0x00, 0x00, 0x00, 0x86, 0x3c, 0xa2, 0x00, 0xa0, 0x80, 0x00, 0x03, 0x03, 0x01 }; char tcp_synack_buf[74]={ 0xd0, 0x00, 0xc0, 0x59, 0x08, 0xb0, 0xd0, 0x00, 0xf1, 0xca, 0x21, 0x26, 0x00, 0x08, 0x00, 0x45, 0x3c, 0x00, 0xbc, 0xd3, 0x00, 0x40, 0x06, 0x40, 0xa9, 0xb5, 0x63, 0x01, 0xa8, 0xc0, 0x16, 0x01, 0xa8, 0xc0, 0x24, 0x21, 0x1b, 0x04, 0xd0, 0x78, 0xbb, 0xa4, 0x3b, 0xef, 0x72, 0xb9, 0x12, 0xa0, 0xa0, 0x16, 0x40, 0x65, 0x00, 0x00, 0xb4, 0x05, 0x04, 0x02, 0x02, 0x04, 0x86, 0x3c, 0x00, 0xa2, 0x61, 0x1e, 0x01, 0x00, 0x0a, 0x08, 0x00, 0x03, 0x03, 0x01 }; char tcp_ack_buf[66]={ 0xd0, 0x00, 0xf1, 0xca, 0x21, 0x26, 0xd0, 0x00, 0xc0, 0x59, 0x08, 0xb0, 0x00, 0x08, 0x00, 0x45, 0x34, 0x00, 0xbd, 0xd3, 0x00, 0x40, 0x06, 0x40, 0xf3, 0xe1, 0x16, 0x01, 0xa8, 0xc0, 0x63, 0x01, 0xa8, 0xc0, 0x1b, 0x04, 0x24, 0x21, 0x3b, 0xef, 0x72, 0xb9, 0xd1, 0x78, 0xbb, 0xa4, 0x10, 0x80, 0xd0, 0x16, 0xd5, 0x93, 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x00, 0x00, 0x86, 0x3c, 0xa2, 0x00, 0xa0, 0x80 };
Forums:
제 기억이 맞다면SYN과 ACK 정보를 담은 패킷을 보내기 위해서
제 기억이 맞다면
SYN과 ACK 정보를 담은 패킷을 보내기 위해서는 커널 레벌의 코드를 수정하지 않으면 안됩니다.
이렇게 되는 이유는 .. 일반 App 레벨에서 이런 조작이 가능해지면 보안과 관련된 문제가 발생하기 때문으로 알고 있습니다.
일하는 사람들의 희망 민주노동당 : http://www.kdlp.org
반공 교육의 성과로, 민주주의의 반대가 공산주의(또는 사회주의)라고 생각하는 사람이 많다.
RAW 소켓을 사용하세요.
socket 을 만들 떄 보통 RAW 소켓으로 만드시면 커널에서 Link Layer까지만 처리합니다. TCP/IP 헤더를 직접 구성하실 수 있습니다. 당연히 root만 가능합니다. :)
http://kali.kaist.ac.kr/~genesis/tt/attach/1205/051205234854009544/199668.jpg
갑자기 위 그림이 생각나네요. :)
댓글 달기