Partager via


ipv4_is_match()

S’applique à : ✅Microsoft Fabric✅Azure Data ExplorerAzure MonitorMicrosoft Sentinel

Met en correspondance deux chaînes IPv4. Les deux chaînes IPv4 sont analysées et comparées tout en tenant compte du masque combiné de préfixe IP calculé à partir des préfixes d’argument et de l’argument facultatif prefix .

Syntaxe

ipv4_is_match(préfixe ip1,ip2[ ,])

En savoir plus sur les conventions de syntaxe.

Paramètres

Nom Type Requise Description
ip1, ip2 string ✔️ Expression représentant une adresse IPv4. Les chaînes IPv4 peuvent être masquées à l’aide de la notation de préfixe IP.
prefix int Entier compris entre 0 et 32 représentant le nombre de bits les plus significatifs pris en compte.

Notation de préfixe IP

La notation de préfixe IP (également appelée notation CIDR) est un moyen concis de représenter une adresse IP et son masque réseau associé. Le format est <base IP>/<prefix length>, où la longueur du préfixe est le nombre de 1 bits de début dans le masque net. La longueur du préfixe détermine la plage d’adresses IP qui appartiennent au réseau.

Pour IPv4, la longueur du préfixe est un nombre compris entre 0 et 32. Ainsi, la notation 192.168.2.0/24 représente l’adresse IP 192.168.2.0 avec un masque netmask de 255.255.255.255.0. Ce masque net a 24 bits de début 1 ou une longueur de préfixe de 24.

Pour IPv6, la longueur du préfixe est un nombre compris entre 0 et 128. Ainsi, la notation fe80 ::85d :e82c :9446:7994/120 représente l’adresse IP fe80 ::85d :e82c :9446:7994 avec un masque net de ffff :ffff :ffff :ffff :ffff :ff00. Ce masque net a 120 bits de début 1 ou une longueur de préfixe de 120.

Retours

  • true: si la représentation longue du premier argument de chaîne IPv4 est égale au deuxième argument de chaîne IPv4.
  • false:Autrement.
  • null: Si la conversion pour l’une des deux chaînes IPv4 n’a pas réussi.

Remarque

Lors de la correspondance avec une adresse IPv4 qui n’est pas une plage, nous vous recommandons d’utiliser l’opérateur égal (==), pour de meilleures performances.

Exemples

Exemple simple

print ipv4_is_match('192.168.1.1/24', '192.168.1.255')

Sortie

print_0
true

Égalité de comparaison IPv4 - Notation de préfixe IP spécifiée à l’intérieur des chaînes IPv4

datatable(ip1_string:string, ip2_string:string)
[
 '192.168.1.0',    '192.168.1.0',       // Equal IPs
 '192.168.1.1/24', '192.168.1.255',     // 24 bit IP-prefix is used for comparison
 '192.168.1.1',    '192.168.1.255/24',  // 24 bit IP-prefix is used for comparison
 '192.168.1.1/30', '192.168.1.255/24',  // 24 bit IP-prefix is used for comparison
]
| extend result = ipv4_is_match(ip1_string, ip2_string)

Sortie

ip1_string ip2_string result
192.168.1.0 192.168.1.0 true
192.168.1.1/24 192.168.1.255 true
192.168.1.1 192.168.1.255/24 true
192.168.1.1/30 192.168.1.255/24 true

Égalité de comparaison IPv4 : notation de préfixe IP spécifiée dans les chaînes IPv4 et un argument supplémentaire de la ipv4_is_match() fonction

datatable(ip1_string:string, ip2_string:string, prefix:long)
[
 '192.168.1.1',    '192.168.1.0',   31, // 31 bit IP-prefix is used for comparison
 '192.168.1.1/24', '192.168.1.255', 31, // 24 bit IP-prefix is used for comparison
 '192.168.1.1',    '192.168.1.255', 24, // 24 bit IP-prefix is used for comparison
]
| extend result = ipv4_is_match(ip1_string, ip2_string, prefix)

Sortie

ip1_string ip2_string prefix result
192.168.1.1 192.168.1.0 31 true
192.168.1.1/24 192.168.1.255 31 true
192.168.1.1 192.168.1.255 24 true