소켓프로그래밍중.. 질문임돠..

익명 사용자의 이미지

안녕하세요~~~ ^^

제가 DNS와 gethostbyname을 공부하던 중에 궁금한 것이 있어서 이렇게
글을 남깁니다.

일반적으로 gethostbyname 함수를 사용하여 쿼리를 날리면 DNS서버가 그
질문에 대해 응답을 하지요.

여기서 DNS 서버가 전송하는 응답 데이터의 모든 내용을 볼 수 있는 방법
은 없나요?

이 Domain 데이터 패킷 포맷 형식과 그 반환값들을 모두 알았으면 좋겠는
데.... 대충 제가 아는걸 말하면

일단 해더가 있는데 이 해더 안에는 ID, QR, OPCODE, RD, RA 등등이 있
고, Question Section 에는

QNAME, QTYPE , QCLASS 가 있고, Resource record format 에는 NAME,
TYPE, CLASS 등이 있다고

합니다. 이 필드들에 대해 그 값들을 모두 알아낼 수 있는 방법이 없을까
요?

GETHOSTBYNAME함수의 반환값 부분을 수정하면 될것도 같은데... 잘 안되는
군요..

워낙 프로그래밍 실력이 딸려서리..

좋은 답변 기다리겠습니다. 수고하세요~~^^

익명 사용자의 이미지

안녕하세요...

이 같은 경우에는 sniffit 라는 프로그램으로 해결이 가능할 것 같습니다.
이 프로그램은 기본적으로 얼마의 크기의 패킷 크기로 설정이 되어 있는
데...
이건 옵션에서 설정이 가능합니다.
이 부분은 메뉴얼을 보시면은 됩니다.
그리고 이 프로그램은 root로만 실행이 가능합니다.
참고 하시길...

_ 信

익명 사용자의 이미지

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

>

익명 사용자의 이미지

감사합니다. 잘 봤습니다.. ^^

그런데요.. 디버깅 툴을 이용하지 않고, 어던 함수 같은걸 사용해서 하
는 방법은 없냐요?

root 계정으로만 가능한가요?

일반 계정으로 할 수 있는 함수는 없나요? -_-;

이게 끝이 아니고 이런 정보를 얻은 다음 이 정보들을 이용해서 다른 작업
을 하려고 하다보니.. 이런 방법이 필요하네요..

익명 사용자의 이미지

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 함수를 만들수 있을것
같군요

익명 사용자의 이미지

DNS 쿼리의 결과 데이터의 형식이 아주 자세히 나와있을겁니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.