DNSSEC (Domain Name System Security Extensions) is an extension of the DNS protocol that adds security to the DNS protocol by signing the records by a public / private key system.
This extension allows the client to verify that the response received is valid and has not been changed by a man-in-the-middle attack.
This extension is standardized by the following RCF :
To illustrate this tutorial, we are going to have how to sign a zone on domain controller.
Sign a zone with DNSSEC on Windows Server
Open the DNS Manager console and go to the Forward Lookup Zones 1 node. It can be seen that the DNSSEC state of the lab.intra zone is Unsigned 2 .
data:image/s3,"s3://crabby-images/bc39d/bc39d1b96c6874aa963e42ed194760b7d6433c12" alt="Zones overview"
Right-click on the zone to sign 1 , go to DNSSEC 2 then click on Sign zone 3 to launch the wizard.
data:image/s3,"s3://crabby-images/92ffe/92ffebe3540fcd3d6caf35022c1275028940222d" alt="Param DNSSEC for zone"
When launching the wizard, click Next 1 .
data:image/s3,"s3://crabby-images/b9552/b9552ec9c2b15affe2bb4013875394db8898938c" alt="Wizard DNSSEC configuration"
Choose the option Customize zone signature settings 1 and click Next 2 .
data:image/s3,"s3://crabby-images/b7e27/b7e277521cd997c878bf9d1ded414b4ea6e0c003" alt="DNSSEC signature options"
Choose the server to put keys 1 and click Next 2 .
data:image/s3,"s3://crabby-images/17c16/17c168bf778a07bbefe89b2a3c856a9f331349d8" alt="Master of keys for DNSSEC"
A summary of the KSK key is displayed (this is used to sign a zone), click on Next 1 .
data:image/s3,"s3://crabby-images/e3fbb/e3fbb033d3d0a4c33a6d72461a2a294073d02f92" alt="KSK key"
Click on Add 1 .
data:image/s3,"s3://crabby-images/1c9cb/1c9cb77f01ebe4005a508071eced22b568155a9e" alt="Wizard DNSSEC add KSK"
Click OK 1 to validate the parameters of the KSK key.
data:image/s3,"s3://crabby-images/a0d7a/a0d7af629dd2622888c7d854bbe00abb85b68221" alt="Params key KSK"
KSK key is added 1 click Next 2 .
data:image/s3,"s3://crabby-images/02f96/02f968e3283e93f24f3b022530e34f1cc7a4867a" alt="Key KSK added"
A summary of the ZSK key (data / record signature) is displayed, click Next 1 .
data:image/s3,"s3://crabby-images/cbb21/cbb21d8864e5c212018a81d2b08faa57e3c1bfb5" alt="DNSSEC - key ZSK"
Click Add 1 to configure the ZSK key.
data:image/s3,"s3://crabby-images/c9446/c944675faa12c3a829ad3c8fd76b60dce0a9158b" alt="Add ZSK key"
Click OK 1 to validate the parameters of the ZSK key.
data:image/s3,"s3://crabby-images/00e76/00e7600dfb4b792dcaf705de79ed5b3d04acff21" alt="DNSSEC - key ZSK param"
The key ZSK is added 1 , click Next 2 .
data:image/s3,"s3://crabby-images/40395/4039503ef453ddc166fb1da5aa8851d38393b953" alt="DNSSEC - key ZSK added"
Select the protocol NSEC3 1 then click Next 2 .
data:image/s3,"s3://crabby-images/cb4a6/cb4a6bf282174620bb31a449aed3516d6a55e551" alt="DNSSEC - select NSEC3"
Leave the default options on the configuration of the approval anchors, click Next 1 .
data:image/s3,"s3://crabby-images/7ab6c/7ab6c9fe74d5084f57bfb6417d9900444b614347" alt="Anchor config"
Leave the signature settings by default, click Next 1 .
data:image/s3,"s3://crabby-images/94c47/94c47cb1c61d9fe1abb370d36b7da7856277a211" alt="DNSSEC - param signature"
A summary of the DNSSEC configuration is displayed, click Next 1 to validate it.
data:image/s3,"s3://crabby-images/5ca40/5ca401cdb8b438bba83ac6f6193c4dcc9b490bb3" alt="Summary config dnssec"
The configuration applied to the zone, leave the wizard by clicking Close 1 .
data:image/s3,"s3://crabby-images/f02b0/f02b02c227fc6543a893fc9e535a4934e768c5a0" alt="signed zone"
Refresh the zone in the DNS Manager console, we see that a padlock has been added to the zone folder to indicate that the zone is singed with DNSSEC and several RRSIG, DNSKEY, NSEC3 … records have been added. Each record contains its signature with an RRSIG record of the same name.
Use DNSSEC
On a DNS client node, open a PowerShell command prompt and enter the following command:
Resolve-DnsName -Server
data:image/s3,"s3://crabby-images/0cdcf/0cdcfb882196366d99f6fb9c1c57cbbf6390b9f5" alt="resolver-dnsname"
The DNS server returned a “normal” response, without any signing information.
To force a query and especially a secure response, add the -DnssecOK parameter to the previous command.
Resolve-DnsName -Server -DnssecOK
data:image/s3,"s3://crabby-images/410b1/410b1564f38216990ab40b9ee1c07f9913067ec4" alt="resolver-dnsname"
We can see the signature parameters in the answer.
Group Policy for a DNSSEC Resolution
As we have just seen, to recover a secure record, it is necessary to inform Windows to do so. In order for the extensions in the domain to use DNSSEC, we will add a Group Policy that will configure the NRPT (Name Resolution Policy) table of the computers to indicate that the zone is signed.
On a domain controller, open the Group Policy Management console, right-click on domain 1 and click Create GPO in this domain and link it here 2 .
data:image/s3,"s3://crabby-images/149a3/149a308b451b1b0f4746bb0da593302a0d433044" alt="New GPO"
Name the GPO 1 then click OK 2 .
data:image/s3,"s3://crabby-images/2782f/2782f6dc883181596f80c17dc815fe17e45240a1" alt="Nammed GPO for DNSSEC"
Right click on the added strategy 1 and click on Edit 2 .
data:image/s3,"s3://crabby-images/5b209/5b209ade2816b8b1478f93f1ab5926844ff172bb" alt="Edit GPO"
Go to Computer Configuration / Windows Settings / Name Resolution Policy 1 . Enter the DNS suffix of the signed area 2 , check that the Enable DNSSEC in this rule 3 and Ask DNS clients to verify address name data check boxes have been validated by the DNS server 4 are ticked and click on Create 5 .
data:image/s3,"s3://crabby-images/1bc6c/1bc6c68fd3e75337968967d66f267ca0bab2e8c0" alt="Config DNSSEC"
The domain has been at the name resolution strategy table 1 , click Apply 2 .
data:image/s3,"s3://crabby-images/151ce/151cefa87e92610f123300e8381af1d1ca83f6ca" alt="zone added"
Summary of the strategy:
data:image/s3,"s3://crabby-images/56c2e/56c2eab9778d29533e762cc3ef669bd738bde4ba" alt="GPO DNSSEC Overview"
On a node in the domain where the policy is applied (gpupdate), open a PowerShell command prompt and enter the following command :
Resolve-DnsName <RecordInZone>
The command must return the IP address with the signature information.
data:image/s3,"s3://crabby-images/ee234/ee2344ac334ed885c0af6adb4550134dcdfb88fd" alt="DNSSEC resolve name"