Node.js – dnsPromises.lookup() 方法
**dnsPromises.lookup()** 方法將主機名(例如,tutorialspoint.com)解析為找到的第一個 A (IPv4) 或 AAAA (IPv6) 記錄。**options** 中的屬性是可選的。
**dns.lookup()** 與 DNS 協議無關。該實現使用可以將名稱與地址關聯起來的反之亦然的 OS 功能。
**dnsPromises** 和 **dns** 模組的區別在於,dns.promises 提供了一種替代的非同步 DNS 方法,它返回 **Promise** 物件而不是回撥函式。
語法
dnsPromises.lookup(hostname, [options])
引數
**hostname** – 這是您要查詢 DNS 值的網站主機名。
**options** – 它可以包含以下選項
**family** – 它只能取值 4、6 或 0。值 0 表示返回 IPv4 和 IPv6 地址。
**hints** – 它啟用一個或多個 **getAddrinfoflags**。
**all** – 當此值設定為 True 時,回撥函式將所有解析的地址以陣列形式返回,否則返回單個地址。
**verbatim** – 當設定為 True 時,回撥函式按 DNS 解析器返回它們的順序返回。
示例 1
建立一個名為 **"lookup.js"** 的檔案並複製以下程式碼片段。建立檔案後,使用命令 **"node lookup.js"** 來執行此程式碼。
// dns.lookup() method Demo Example
// Importing the dns module
const dns = require('dns');
const dnsPromises = dns.promises;
// Passing some options for dns.lookup()
const options = {
family: 6,
hints: dns.ADDRCONFIG | dns.V4MAPPED,
};
// Result will be an array, when all the options are true
dnsPromises.lookup('tutorialspoint.com', options).then((response) =>
{
console.log('addresses: %j', response);
});輸出
C:\home
ode>> node lookup.js addresses: {"address":"64:ff9b::5fd9:4a92","family":6}
示例 2
// dns.lookup() method Demo Example
// Importing the dns module
const dns = require('dns');
const dnsPromises = dns.promises;
// Setting options for dnsPromises.lookup()
// method, all as true
const options = {
all:true,
};
// Result will be an array, when all the options are true
dnsPromises.lookup('tutorialspoint.com', options).then((response) =>
{
console.log('addresses: %j', response);
});輸出
C:\home
ode>> node lookup.js addresses: [{"address":"95.217.74.146","family":4},{"address":"64:ff9b::5fd9 :4a92","family":6}]
廣告
資料結構
網路
關係資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP