소켓프로그래밍중.. 질문임돠..
글쓴이: 익명 사용자 / 작성시간: 월, 2002/05/06 - 4:04오후
안녕하세요~~~ ^^
제가 DNS와 gethostbyname을 공부하던 중에 궁금한 것이 있어서 이렇게
글을 남깁니다.
일반적으로 gethostbyname 함수를 사용하여 쿼리를 날리면 DNS서버가 그
질문에 대해 응답을 하지요.
여기서 DNS 서버가 전송하는 응답 데이터의 모든 내용을 볼 수 있는 방법
은 없나요?
이 Domain 데이터 패킷 포맷 형식과 그 반환값들을 모두 알았으면 좋겠는
데.... 대충 제가 아는걸 말하면
일단 해더가 있는데 이 해더 안에는 ID, QR, OPCODE, RD, RA 등등이 있
고, Question Section 에는
QNAME, QTYPE , QCLASS 가 있고, Resource record format 에는 NAME,
TYPE, CLASS 등이 있다고
합니다. 이 필드들에 대해 그 값들을 모두 알아낼 수 있는 방법이 없을까
요?
GETHOSTBYNAME함수의 반환값 부분을 수정하면 될것도 같은데... 잘 안되는
군요..
워낙 프로그래밍 실력이 딸려서리..
좋은 답변 기다리겠습니다. 수고하세요~~^^
Forums:
Re: 소켓프로그래밍중.. 질문임돠..
안녕하세요...
이 같은 경우에는 sniffit 라는 프로그램으로 해결이 가능할 것 같습니다.
이 프로그램은 기본적으로 얼마의 크기의 패킷 크기로 설정이 되어 있는
데...
이건 옵션에서 설정이 가능합니다.
이 부분은 메뉴얼을 보시면은 됩니다.
그리고 이 프로그램은 root로만 실행이 가능합니다.
참고 하시길...
_ 信
Re: 소켓프로그래밍중.. 질문임돠..
nslookup에서 디버깅 모드를 키면
아래와 같이 상세한 정보를 얻을 수가 있지요..
ftp//ftp.isc.org/isc/bind/src/8.3.1/bind-src.tar.gz
여기 소스를 받아서 nslookup 소스를 함 분석해보세요..
[root@hyuna /root]# nslookup
Default Server ns.dacom.co.kr
Address 164.124.101.2
> set debug
> www.ezdoum.com
Server ns.dacom.co.kr
Address 164.124.101.2
;; res_nmkquery(QUERY, www.ezdoum.com, IN, A)
------------
Got answer
HEADER
opcode = QUERY, id = 23188, rcode = NOERROR
header flags response, auth. answer, want recursion,
recursion avail.
questions = 1, answers = 2, authority records = 2,
additional = 2
QUESTIONS
www.ezdoum.com, type = A, class = IN
ANSWERS
-> www.ezdoum.com
canonical name = ezdoum.com
ttl = 21600 (6H)
-> ezdoum.com
internet address = 210.207.37.202
ttl = 21600 (6H)
AUTHORITY RECORDS
-> ezdoum.com
nameserver = ns1.kidc.net
ttl = 21600 (6H)
-> ezdoum.com
nameserver = ns2.kidc.net
ttl = 21600 (6H)
ADDITIONAL RECORDS
-> ns1.kidc.net
internet address = 203.248.250.24
ttl = 7200 (2H)
-> ns2.kidc.net
internet address = 203.248.250.25
ttl = 7200 (2H)
------------
Name ezdoum.com
Address 210.207.37.202
Aliases www.ezdoum.com
>
Re^2 : 답변 감사함돠.. 그런데요...
감사합니다. 잘 봤습니다.. ^^
그런데요.. 디버깅 툴을 이용하지 않고, 어던 함수 같은걸 사용해서 하
는 방법은 없냐요?
root 계정으로만 가능한가요?
일반 계정으로 할 수 있는 함수는 없나요? -_-;
이게 끝이 아니고 이런 정보를 얻은 다음 이 정보들을 이용해서 다른 작업
을 하려고 하다보니.. 이런 방법이 필요하네요..
Re^3: Re^2 : nslookup의 소스를 분석해서..
nslookup의 디버깅 모드는 일반 사용자도 됩니다.
제가 nslookup의 예를 올린것은..
nslookup의 소스를 분석해보시라는 거죠..
bind/src/bin/nslookup/send.c
* SendRequest --
*
* Sends a request packet to a name server whose address
* is specified by the first argument and returns with
* the answer packet.
*
를 보시면 소켓을 만들어서 전송하고
응답을 받아서 Print_query 함수로 분석하는 내용입니다.
이걸 참조하시면 원하는 gethostbyname 함수를 만들수 있을것
같군요
Re: RFC 1035 입니다.
DNS 쿼리의 결과 데이터의 형식이 아주 자세히 나와있을겁니다.
댓글 달기