TXT record
A TXT record is a type of resource record in the Domain Name System used to provide the ability to associate arbitrary text with a host or other name, such as human readable information about a server, network, data center, or other accounting information.
It is also often used in a more structured fashion to record small amounts of machine-readable data into the DNS.
Background
A domain may have multiple TXT records associated with it, provided the DNS server implementation supports this. Each record can in turn have one or more character strings. Traditionally these text fields were used for a variety of non-standardised uses, such as a full company or organisation name, or the address of a host.Some examples of TXT usage:
- Verification of domain ownership
- Implementation of Sender Policy Framework
- DomainKeys Identified Mail records for verifying the sender of email messages
- Zero-configuration networking DNS-based service discovery
- Domain-based Message Authentication, Reporting and Conformance policies
Format
The structure of the TXT record is specified in RFC 1035 as follows. Note that the specification is silent on the subject of character encoding of the text string. It explicitly states that the interpretation of the string is context dependent, and that the data is treated as binary inside the DNS. Later specifications may require the use of specific encodings for specific purposes.The RDATA section may contain multiple consecutive occurrences of. Data Length is the length of them all combined.
| Field | Type | Description |
| Name | Label Sequence | The domain name, encoded as a sequence of labels. |
| Type | 2-byte Integer | The record type. In this case will be as the Type is TXT. |
| Class | 2-byte Integer | The class. |
| TTL | 4-byte Integer | Time-To-Live, i.e. how long a record can be cached before it should be requeried. |
| Data Length | 2-byte Integer | Length of the record type-specific data. |
| TXT Length | 1-byte Integer | Length of TXT string. |
| TXT | String | The character-string. |
This is the hex returned as part of the DNS response from example.com when queried for TXT records.
0000 34 48 81 a0 00 01 00 02 00 00 00 01 07 65 78 61
0010 6d 70 6c 65 03 63 6f 6d 00 00 10 00 01 c0 0c 00
0020 10 00 01 00 00 54 5f 00 0c 0b 76 3d 73 70 66 31
0030 20 2d 61 6c 6c c0 0c 00 10 00 01 00 00 54 5f 00
0040 21 20 38 6a 35 6e 66 71 6c 64 32 30 7a 70 63 79
0050 72 38 78 6a 77 30 79 64 63 66 71 39 72 6b 38 68
0060 67 6d 00 00 29 02 00 00 00 00 00 00 00
As part of this response, there are two text records, the first of which is shown below.
0000 c0 0c 00 10 00 01 00 00 54 5f 00 0c 0b 76 3d 73
0010 70 66 31 20 2d 61 6c 6c
This decodes as follows:
| Field | Hex | Value |
| Name | example.com | |
| Type | 0x0010 | TXT |
| Class | IN | |
| TTL | 21599 | |
| 0x000c | 12 | |
| TXT Length | 11 | |
| TXT | v=spf1 -all |
As unstructured text, organisations can use the TXT string in any way they define, for example:
defines a structured format that can be used to define attributes and their values in a single record, as in these examples:
In practice, services using TXT records often do not follow this RFC, but instead have their own specific format.
Example usage
The character string from a TXT record used for SPF:"v=spf1 ip4:192.0.2.0/24 ip4:198.51.100.123 ip6:2620:0:860::/46 a -all"
An example of use for DMARC:
Use for site verification:
Use for custom email service:
Brand Indicators for Message Identification :