首頁 web前端 js教程 在Node.js中如何使用DNS模組(詳細教學)

在Node.js中如何使用DNS模組(詳細教學)

Jun 02, 2018 pm 05:23 PM
javascript node.js 詳細

本篇文章給大家詳細介紹了Node.js中DNS模組的相關知識點,以及相關的實例程式碼做了分享,有興趣的朋友參考下。

1. DNS

在Node.js中,提供DNS模組,以實現網域名稱查找及網域解析的處理。

  • 在DNS模組中,提供了三個主方法及一系列便捷方法。

  • resolve方法:用於將一個網域解析為一組DNS記錄。

  • reverse方法: 用於將IP位址轉換為一組網域名稱。

  • lookup方法: 用來將一個網域轉換成IP位址。

  • DNS模組中的其餘便捷方法均為resolve方法的一種便捷形式。

2. 使用resolve方法將網域解析為DNS記錄

`DNS.resolve(domain, [rrtype ], callback(err, address){...})`

domain參數為一個字串,用於指定需要被解析的域名,可以包括子域名。
rrtypr參數為字串,用於指定需要取得的記錄類型,可指定的記錄類型如下。

  • A,此參數值為預設值,當記錄類型為A時,該記錄將一個IPv4位址對應為一個網域名稱。

  • AAAA,當記錄類型為AAAA時,該記錄將一個IPv6位址對應為一個網域名稱。

  • CNAME,當記錄類型為CNAME時,表示該記錄為一個網域的別名記錄,例如,一個www.example.com網域記錄也許為一個example.com網域記錄額別名記錄。

  • MX,MX記錄指向一個使用SMTP的網域中的郵件伺服器,例如,當你想要person@domain.com郵件地址發送電子郵件時,domain.com網域的MX記錄中保存了發送該郵件時的郵件伺服器位址。

  • TXT,TXT記錄是為該網域附加的描述記錄。

  • SRV,SRV記錄用於為一個特定網域中所有可用服務提供資訊。

  • PTR,PTR記錄用於反向位址解析,該記錄將一個網域名稱對應為一個IPv4位址。

  • NS,NS(Name Server)記錄是網域名稱伺服器記錄,用來指定該網域由哪個DNS伺服器解析。

回呼函數有兩個參數,err是網域解析失敗時觸發的錯誤對象,addresses參數為數組,其中存放了所有取得到的DNS記錄。

3. 為resolve方法定制的各種便捷方法

  • DNS.resolve4(domain, callback),取得IPv4位址

  • DNS.resolve6(domain, callback),取得IPv6位址

  • ##DNS.resolveMx(domain, callback),取得MX記錄,郵件交換伺服器記錄

  • DNS.resolveTxt(domain, callback),取得TXT記錄,網域附加的描述記錄

  • DNS. resolveSrv(domain, callback),取得SRV記錄,服務記錄

  • DNS.resolveNs(domain, callback),取得NS記錄,網域名稱伺服器記錄

  • #DNS.resolveCname(domain, callback),取得別名記錄

#4. 使用lookup方法查詢IP位址

當使用resolve4方法或resolve6方法時,由於callback參數值回呼函數中的addresses參數值數組中存放著所有取得到的IPv4位址或IPv6位址。因此DNS模組中提供了一個取得第一個被發現的IPv4位址或IPv6位址的lookup方法


`DNS.lookup(domain, [family], callback(err, addresses, family) {...})`

  • domain參數為字串,用於指定需要解析的網域名稱

  • family參數值為一個整數值,用於指定需要取得的IP位址類型,可指定的參數值為4或6,預設參數值為null,表示既可以取得IPv4,又可以取得IPv6

  • 回呼函數err參數值為取得位址失敗時觸發的錯誤對象,當網域不存在或查詢失敗時該錯誤對象的code屬性值為ENOENT

  • addresses參數值為一個字串,為取得到的IP位址

  • family參數值為4時,表示為一個IPv4位址,為6時,表示為一個IPv6位址。

5. 使用reverse方法反向解析IP位址

#在DNS模組中,使用reverse方法將IP位址反向解析為一組與此IP位址綁定的網域名稱


`DNS.reverse(ip, callback(err, domains){...})`

  • ip參數值為一個字串,用於指定需要解析的IP位址

  • 回呼函數的err為反向解析位址失敗後的錯誤物件

  • domains參數值為一個數組,存放了所有取得到的網域名稱

6. DNS模組中的各種錯誤代碼

err參數值為執行各種解析或反向解析操作時觸發的錯誤對象,可根據該錯誤對象的code屬性值,即觸發的錯誤代號判斷出發了什麼錯誤

  • ENODATA:DNS伺服器傳回一個沒有資料的查詢結果

  • EFORMERR:DNS伺服器發現客戶端請求查詢時使用了格式錯誤的查詢參數

  • ESERVFAIL:DNS伺服器執行查詢操作失敗

  • ENOTFOUND:未發現任何網域名稱

  • ENOTIMP:DNS伺服器不能進行客戶端所要求的查詢操作

  • EREFUSED:DNS伺服器拒絕進行查詢操作

  • ##EBADQUERY:格式錯誤的DNS查詢

  • EBADNAME:網域名稱格式錯誤

  • EBADFAMILY:不支援的IP位址類型

  • EBADRESP:DNS答案的格式錯誤

  • ECONNREFUSED:不能建立與DNS伺服器之間的連線

  • ETIMEOUT:與DNS伺服器之間建立連線逾時

  • EEOF:已到達檔案底部

  • EFILE:讀取檔案失敗

  • ENOMEM:沒有足夠的記憶體空間

  • EDESTRUCTION:通道已經被銷毀

  • EBADSTR:字串格式錯誤

  • #EBADFLAGS:指定了錯誤的判斷標誌

  • ENONAME:指定的主機名稱不是數值格式的

  • EBADHINTS:指定的提示標誌無效

  • ENOTINITIALIZED:c-ares類別庫初始化工作尚未完成

  • ELOADIPHLPAPI:載入iphlpapi.dll時觸發了一個錯誤

  • EADDREGETNETWORKPARAMS:未發現GetNetworkParams函數

  • ##ECANCELLED:DNS查詢操作被取消


#7. DNS模組的基本使用

const dns = require('dns');
let url = 'www.qq.com';

dns.resolve(url, 'A', (err, addresses) => {
  console.log(addresses);
  // IPv4地址 [ '103.7.30.123' ]
});

dns.resolve(url, 'AAAA', (err, addresses) => {
  console.log(addresses);
  // IPv6地址 [ '240e:e1:8100:28::2:16' ]
});
dns.resolveMx('qq.com', (err, addresses) => {
  console.log(addresses);
  // 邮件交换服务器记录
  // [ { exchange: 'mx2.qq.com', priority: 20 },
  //  { exchange: 'mx1.qq.com', priority: 30 },
  //  { exchange: 'mx3.qq.com', priority: 10 } ]
  
});

dns.resolveTxt('qq.com', (err, addresses) => {
  console.log(addresses);
  // 域名附加的描述记录
  // [ [ 'v=spf1 include:spf.mail.qq.com -all' ] ]
});

dns.resolveSrv('www.baidu.com', (err, addresses) => {
  console.log(addresses);
  // 服务记录
  // []
});

dns.resolveNs('www.github.com', (err, addresses) => {
  console.log(addresses);
  // 域名服务器记录
  // [ 'ns-421.awsdns-52.com',
  // 'ns-520.awsdns-01.net',
  // 'ns1.p16.dynect.net',
  // 'ns2.p16.dynect.net',
  // 'ns3.p16.dynect.net',
  // 'ns4.p16.dynect.net',
  // 'ns-1283.awsdns-32.org',
  // 'ns-1707.awsdns-21.co.uk' ]
});

dns.resolveCname('www.163.com', (err, addresses) => {
  console.log(addresses);
  // 获取别名记录
  // [ 'www.163.com.lxdns.com' ]
});


dns.lookup('google.com', 4, (err, address, family) => {
  // 查询IP地址
  // address,查询到的地址
  // family,IPv4或IPv6
  console.log(address);// 172.217.27.142
  console.log(family);// 4
});

dns.lookup('google.com', 6, (err, address, family) => {
  console.log(address);// 2404:6800:4008:803::200e
  console.log(family);// 6
});

dns.reverse('203.188.200.67', (err, domain) => {
  // 反向解析IP地址
  console.log(domain);
  // [ 'media-router-fp1.prod.media.vip.tp2.yahoo.com' ]
});
登入後複製

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

vue-router相關基礎與工作原理

#axios post提交formdata的實例

在vue元件中使用axios的方法

以上是在Node.js中如何使用DNS模組(詳細教學)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統 如何使用WebSocket和JavaScript實現線上語音辨識系統 Dec 17, 2023 pm 02:54 PM

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術 WebSocket與JavaScript:實現即時監控系統的關鍵技術 Dec 17, 2023 pm 05:30 PM

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統 如何利用JavaScript和WebSocket實現即時線上點餐系統 Dec 17, 2023 pm 12:09 PM

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統 如何使用WebSocket和JavaScript實現線上預約系統 Dec 17, 2023 am 09:39 AM

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript與WebSocket:打造高效率的即時天氣預報系統 JavaScript與WebSocket:打造高效率的即時天氣預報系統 Dec 17, 2023 pm 05:13 PM

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

javascript如何使用insertBefore javascript如何使用insertBefore Nov 24, 2023 am 11:56 AM

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript與WebSocket:打造高效率的即時影像處理系統 JavaScript與WebSocket:打造高效率的即時影像處理系統 Dec 17, 2023 am 08:41 AM

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數

See all articles