Package org.minidns.dnsmessage
Class DnsMessage
- java.lang.Object
- 
- org.minidns.dnsmessage.DnsMessage
 
- 
 public class DnsMessage extends Object A DNS message as defined by RFC 1035. The message consists of a header and 4 sections: question, answer, nameserver and addition resource record section. A message can either be parsed (DnsMessage(byte[])) or serialized (toArray()).- See Also:
- RFC 1035
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classDnsMessage.Builderstatic classDnsMessage.OPCODESymbolic DNS Opcode values.static classDnsMessage.RESPONSE_CODEPossible DNS response codes.
 - 
Field SummaryFields Modifier and Type Field Description List<Record<? extends Data>>additionalSectionThe additional section.List<Record<? extends Data>>answerSectionThe answers section records.booleanauthenticDataTrue if the server regarded the response as authentic.booleanauthoritativeAnswerTrue if this is a authorative response.List<Record<? extends Data>>authoritySectionThe Authority Section.booleancheckingDisabledTrue if the server should not perform DNSSEC validation before returning the result.intidThe DNS message id.DnsMessage.OPCODEopcodeThe DNS message opcode.intoptRrPositionbooleanqrThe QR flag of the DNS message header.List<Question>questionsThe question section content.longreceiveTimestampThe receive timestamp.booleanrecursionAvailableTrue if recursion is possible.booleanrecursionDesiredTrue if the server should recurse.DnsMessage.RESPONSE_CODEresponseCodeThe response code of this dns message.booleantruncatedTrue if message is truncated.
 - 
Constructor SummaryConstructors Modifier Constructor Description DnsMessage(byte[] data)Build a DNS Message based on a binary DNS message.protectedDnsMessage(DnsMessage.Builder builder)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description DnsMessage.BuilderasBuilder()DatagramPacketasDatagram(InetAddress address, int port)DnsMessageasNormalizedVersion()StringasTerminalOutput()Format the DnsMessage object in a way suitable for terminal output.static DnsMessage.Builderbuilder()List<Record<? extends Data>>copyAnswers()Copy the records found in the answer section into a new list.List<Record<? extends Data>>copyAuthority()Copy the records found in the authority section into a new list.List<Question>copyQuestions()Copy the questions found in the question section.booleanequals(Object other)<D extends Data>
 List<Record<D>>filterAdditionalSectionBy(Class<D> type)<D extends Data>
 List<Record<D>>filterAnswerSectionBy(Class<D> type)<D extends Data>
 List<Record<D>>filterAuthoritySectionBy(Class<D> type)<D extends Data>
 Set<D>getAnswersFor(Question q)longgetAnswersMinTtl()Get the minimum TTL from all answers in seconds.EdnsgetEdns()<D extends Data>
 Record<D>getFirstOfTypeFromAdditionalSection(Class<D> type)<D extends Data>
 Record<D>getFirstOfTypeFromAnswerSection(Class<D> type)<D extends Data>
 Record<D>getFirstOfTypeFromAuthoritySection(Class<D> type)ByteBuffergetInByteBuffer()Record<OPT>getOptPseudoRecord()QuestiongetQuestion()DnsMessage.BuildergetResponseBuilder(DnsMessage.RESPONSE_CODE responseCode)inthashCode()booleanisDnssecOk()Check if the EDNS DO (DNSSEC OK) flag is set.byte[]toArray()Generate a binary dns packet out of this message.StringtoString()voidwriteTo(OutputStream outputStream)voidwriteTo(OutputStream outputStream, boolean writeLength)
 
- 
- 
- 
Field Detail- 
idpublic final int id The DNS message id.
 - 
opcodepublic final DnsMessage.OPCODE opcode The DNS message opcode.
 - 
responseCodepublic final DnsMessage.RESPONSE_CODE responseCode The response code of this dns message.
 - 
qrpublic final boolean qr The QR flag of the DNS message header. Note that this will betrueif the message is a response andfalseif it is a query.- See Also:
- RFC 1035 § 4.1.1
 
 - 
authoritativeAnswerpublic final boolean authoritativeAnswer True if this is a authorative response. If set, the responding nameserver is an authority for the domain name in the question section. Note that the answer section may have multiple owner names because of aliases. This flag corresponds to the name which matches the query name, or the first owner name in the query section.- See Also:
- RFC 1035 § 4.1.1. Header section format
 
 - 
truncatedpublic final boolean truncated True if message is truncated. Then TCP should be used.
 - 
recursionDesiredpublic final boolean recursionDesired True if the server should recurse.
 - 
recursionAvailablepublic final boolean recursionAvailable True if recursion is possible.
 - 
authenticDatapublic final boolean authenticData True if the server regarded the response as authentic.
 - 
checkingDisabledpublic final boolean checkingDisabled True if the server should not perform DNSSEC validation before returning the result.
 - 
questionspublic final List<Question> questions The question section content. Usually there will be only one question.This list is unmodifiable. 
 - 
answerSectionpublic final List<Record<? extends Data>> answerSection The answers section records. Note that it is not guaranteed that all records found in this section will be direct answers to the question in the query. If DNSSEC is used, then this section also contains the RRSIG record.This list is unmodifiable. 
 - 
authoritySectionpublic final List<Record<? extends Data>> authoritySection The Authority Section. Note that it is not guaranteed that this section only contains nameserver records. If DNSSEC is used, then this section could also contain a NSEC(3) record.This list is unmodifiable. 
 - 
additionalSectionpublic final List<Record<? extends Data>> additionalSection The additional section. It eventually contains RRs which relate to the query.This list is unmodifiable. 
 - 
optRrPositionpublic final int optRrPosition 
 - 
receiveTimestamppublic final long receiveTimestamp The receive timestamp. Set only if this message was created via parse. This should be used to evaluate TTLs.
 
- 
 - 
Constructor Detail- 
DnsMessageprotected DnsMessage(DnsMessage.Builder builder) 
 - 
DnsMessagepublic DnsMessage(byte[] data) throws IOException Build a DNS Message based on a binary DNS message.- Parameters:
- data- The DNS message data.
- Throws:
- IOException- On read errors.
 
 
- 
 - 
Method Detail- 
toArraypublic byte[] toArray() Generate a binary dns packet out of this message.- Returns:
- byte[] the binary representation.
 
 - 
asDatagrampublic DatagramPacket asDatagram(InetAddress address, int port) 
 - 
writeTopublic void writeTo(OutputStream outputStream) throws IOException - Throws:
- IOException
 
 - 
writeTopublic void writeTo(OutputStream outputStream, boolean writeLength) throws IOException - Throws:
- IOException
 
 - 
getInByteBufferpublic ByteBuffer getInByteBuffer() 
 - 
getQuestionpublic Question getQuestion() 
 - 
copyQuestionspublic List<Question> copyQuestions() Copy the questions found in the question section.- Returns:
- a copy of the question section questions.
- See Also:
- questions
 
 - 
copyAnswerspublic List<Record<? extends Data>> copyAnswers() Copy the records found in the answer section into a new list.- Returns:
- a copy of the answer section records.
- See Also:
- answerSection
 
 - 
copyAuthoritypublic List<Record<? extends Data>> copyAuthority() Copy the records found in the authority section into a new list.- Returns:
- a copy of the authority section records.
- See Also:
- authoritySection
 
 - 
getOptPseudoRecordpublic Record<OPT> getOptPseudoRecord() 
 - 
isDnssecOkpublic boolean isDnssecOk() Check if the EDNS DO (DNSSEC OK) flag is set.- Returns:
- true if the DO flag is set.
 
 - 
asTerminalOutputpublic String asTerminalOutput() Format the DnsMessage object in a way suitable for terminal output. The format is loosely based on the output provided bydig.- Returns:
- This message as a String suitable for terminal output.
 
 - 
getAnswersForpublic <D extends Data> Set<D> getAnswersFor(Question q) 
 - 
getAnswersMinTtlpublic long getAnswersMinTtl() Get the minimum TTL from all answers in seconds.- Returns:
- the minimum TTL from all answers in seconds.
 
 - 
asBuilderpublic DnsMessage.Builder asBuilder() 
 - 
asNormalizedVersionpublic DnsMessage asNormalizedVersion() 
 - 
getResponseBuilderpublic DnsMessage.Builder getResponseBuilder(DnsMessage.RESPONSE_CODE responseCode) 
 - 
filterAnswerSectionBypublic <D extends Data> List<Record<D>> filterAnswerSectionBy(Class<D> type) 
 - 
filterAuthoritySectionBypublic <D extends Data> List<Record<D>> filterAuthoritySectionBy(Class<D> type) 
 - 
filterAdditionalSectionBypublic <D extends Data> List<Record<D>> filterAdditionalSectionBy(Class<D> type) 
 - 
getFirstOfTypeFromAnswerSectionpublic <D extends Data> Record<D> getFirstOfTypeFromAnswerSection(Class<D> type) 
 - 
getFirstOfTypeFromAuthoritySectionpublic <D extends Data> Record<D> getFirstOfTypeFromAuthoritySection(Class<D> type) 
 - 
getFirstOfTypeFromAdditionalSectionpublic <D extends Data> Record<D> getFirstOfTypeFromAdditionalSection(Class<D> type) 
 - 
builderpublic static DnsMessage.Builder builder() 
 
- 
 
-