What is ip-regex?
The ip-regex npm package is a module that provides regular expressions for matching IP addresses. It supports both IPv4 and IPv6 addresses and offers options to match exact strings, exclude CIDR notation, and more.
What are ip-regex's main functionalities?
Matching IPv4 addresses
This feature allows you to match IPv4 addresses in a given string using the ipRegex.v4() method.
const ipRegex = require('ip-regex');
// Match all IPv4 addresses in a string
const text = 'Examples: 192.168.0.1 and 8.8.8.8';
const ips = text.match(ipRegex.v4());
console.log(ips);
Matching IPv6 addresses
This feature allows you to match IPv6 addresses in a given string using the ipRegex.v6() method.
const ipRegex = require('ip-regex');
// Match all IPv6 addresses in a string
const text = 'Examples: 1:2:3:4:5:6:7:8 and ::1';
const ips = text.match(ipRegex.v6());
console.log(ips);
Matching exact IP addresses
This feature allows you to match an exact IP address string using the ipRegex.v4() or ipRegex.v6() method with the 'exact' option set to true.
const ipRegex = require('ip-regex');
// Match an exact IPv4 address
const exactMatch = ipRegex.v4({exact: true}).test('192.168.0.1');
console.log(exactMatch);
Other packages similar to ip-regex
ip
The 'ip' npm package is used for IP address manipulation, such as formatting and parsing IP addresses, but does not focus on regex matching like ip-regex.
is-ip
The 'is-ip' npm package is used to check if a given string is an IP address, which is a similar functionality to ip-regex, but it does not provide regex patterns for matching within larger strings.
cidr-regex
The 'cidr-regex' npm package provides regular expressions for matching CIDR IP addresses. It is similar to ip-regex in that it provides regex patterns, but it is specifically for CIDR notation.
ip-regex
Regular expression for matching IP addresses
Install
$ npm install ip-regex
This module targets Node.js 12 or later and the latest version of Chrome, Firefox, and Safari. If you want support for older browsers, use version 2.1.0: npm install ip-regex@2.1.0
Usage
import ipRegex from 'ip-regex';
ipRegex().test('unicorn 192.168.0.1');
ipRegex({exact: true}).test('unicorn 192.168.0.1');
ipRegex.v6({exact: true}).test('1:2:3:4:5:6:7:8');
'unicorn 192.168.0.1 cake 1:2:3:4:5:6:7:8 rainbow'.match(ipRegex());
ipRegex({includeBoundaries: true}).test('192.168.0.2000000000');
'192.168.0.2000000000'.match(ipRegex({includeBoundaries: true}));
API
ipRegex(options?)
Returns a regex for matching both IPv4 and IPv6.
ipRegex.v4(options?)
Returns a regex for matching IPv4.
ipRegex.v6(options?)
Returns a regex for matching IPv6.
options
Type: object
exact
Type: boolean
Default: false
(Matches any IP address in a string)
Only match an exact string. Useful with RegExp#test()
to check if a string is an IP address.
includeBoundaries
Type: boolean
Default: false
Include boundaries in the regex. When true
, 192.168.0.2000000000
will report as an invalid IPv4 address. If this option is not set, the mentioned IPv4 address would report as valid (ignoring the trailing zeros).
Related
- is-ip - Check if a string is an IP address
- is-cidr - Check if a string is an IP address in CIDR notation
- cidr-regex - Regular expression for matching IP addresses in CIDR notation