互联网私有IP地址列表
最近因为业务需要,要判断用户的IP是否私有IP,
以前知道的私有IP,基本上只有如下几个(注意:这不是正确答案):
- 10.0.0.0/8(10.0.0.0-10.255.255.255)
- 172.16.0.0/12(172.16.0.0-172.31.255.255)
- 192.168.0.0/16(192.168.0.0-192.168.255.255)
- 再加一个本地IP:
127.0.0.0/8(127.0.0.0-127.255.255.255)
localhost - 以前考MCSE的时候,还知道一个Windows在DHCP未获取到IP时,会自动分配的:
169.254.0.0/16(169.254.0.0-169.254.255.255)
之前知道的就这些了,问了一下ChatGPT老师,说还有一些,如图:
基于以往印象中,GPT老师的不靠谱情况,去google查了一些资料,最后搜索到官方的定义文档,对互联网保留地址做了一个清单说明,还贴心的提供了csv格式下载:
https://www.iana.org/assignments/iana-ipv4-special-registry/iana-ipv4-special-registry.xhtml
这个网址是iana的官方网站,iana负责全球的IP地址分配,具体说明参考百度百科:
IANA ( Internet Assigned Numbers Authority,互联网号码分配机构)负责协调全球DNS的根域名、IP地址分配和其他互联网协议资源。
不过iana给的清单还有一些重复,维基百科帮它做了一下合并,整理为17项,参考地址:
https://en.wikipedia.org/wiki/Reserved_IP_addresses
IP地址段 | IP范围 | IP个数 | 范围 | 说明 |
---|---|---|---|---|
0.0.0.0/8 | 0.0.0.0–0.255.255.255 | 16,777,216 | Software | 一般用于当前网络或路由等特殊用途 |
10.0.0.0/8 | 10.0.0.0–10.255.255.255 | 16,777,216 | Private network | 用于大型的私有网络本地通信 |
100.64.0.0/10 | 100.64.0.0–100.127.255.255 | 4,194,304 | Private network | 运营商NAT用,即ISP与客户间通信的地址 |
127.0.0.0/8 | 127.0.0.0–127.255.255.255 | 16,777,216 | Host | 本地主机环回地址。 |
169.254.0.0/16 | 169.254.0.0–169.254.255.255 | 65,536 | Subnet | 一般在DHCP无法获取到地址时,为本机分配的地址 |
172.16.0.0/12 | 172.16.0.0–172.31.255.255 | 1,048,576 | Private network | 用于中型的私有网络本地通信。 |
192.0.0.0/24 | 192.0.0.0–192.0.0.255 | 256 | Private network | IETF协议分配。 |
192.0.2.0/24 | 192.0.2.0–192.0.2.255 | 256 | Documentation | 分配为TEST-NET-1,做文档和示例 |
192.88.99.0/24 | 192.88.99.0–192.88.99.255 | 256 | Internet | 保留。以前用于从IPv6到IPv4中继 |
192.168.0.0/16 | 192.168.0.0–192.168.255.255 | 65,536 | Private network | 用于小型的私有网络本地通信。 |
198.18.0.0/15 | 198.18.0.0–198.19.255.255 | 131,072 | Private network | 用于对2个独立子网间的通信通过基准测试 |
198.51.100.0/24 | 198.51.100.0–198.51.100.255 | 256 | Documentation | 分配为TEST-NET-2,做文档和示例 |
203.0.113.0/24 | 203.0.113.0–203.0.113.255 | 256 | Documentation | 分配为TEST-NET-2,做文档和示例 |
224.0.0.0/4 | 224.0.0.0–239.255.255.255 | 268,435,456 | Internet | 用于IP多播(以前的D类网络) |
233.252.0.0/24 | 233.252.0.0–233.252.0.255 | 256 | Documentation | 指定为 MCAST-TEST-NET,文档和示例 |
240.0.0.0/4 | 240.0.0.0–255.255.255.254 | 268,435,455 | Internet | 保留以备将来使用(以前的E类网络) |
255.255.255.255/32 | 255.255.255.255 | 1 | Subnet | 保留,用于“有限广播”目标地址 |
注:
IPv6的保留地址参考这里:
https://www.iana.org/assignments/iana-ipv6-special-registry/iana-ipv6-special-registry.xhtml
# 转换代码
文章的最后,贴一些转换用的代码吧:
Javascript版本的代码
有5个方法,可以看下面代码的注释:
/*** 判断给定的ip,是否属于 IANA定义的保留地址(即私有地址)* @param ip 给定的ip* @returns {boolean} 是否私有地址*/
function isPrivateIpAddr(ip) {const privateIp = [['0.0.0.0', '0.255.255.255'], // 0.0.0.0/8['10.0.0.0', '10.255.255.255'], // 10.0.0.0/8['100.64.0.0', '100.127.255.255'], // 100.64.0.0/10['127.0.0.0', '127.255.255.255'], // 127.0.0.0/8['169.254.0.0', '169.254.255.255'], // 169.254.0.0/16['172.16.0.0', '172.31.255.255'], // 172.16.0.0/12['192.0.0.0', '192.0.0.255'], // 192.0.0.0/24['192.0.2.0', '192.0.2.255'], // 192.0.2.0/24['192.88.99.0', '192.88.99.255'], // 192.88.99.0/24['192.168.0.0', '192.168.255.255'], // 192.168.0.0/16['198.18.0.0', '198.19.255.255'], // 198.18.0.0/15['198.51.100.0', '198.51.100.255'], // 198.51.100.0/24['203.0.113.0', '203.0.113.255'], // 203.0.113.0/24['224.0.0.0', '239.255.255.255'], // 224.0.0.0/4['233.252.0.0', '233.252.0.255'], // 233.252.0.0/24['240.0.0.0', '255.255.255.254'], // 240.0.0.0/4['255.255.255.255', '255.255.255.254'], // 255.255.255.255/32];for (const [startIP, endIP] of privateIp) {if (inIpAddrRange(ip, startIP, endIP)) {return true;}}return false;
}/*** 把 x.x.x.x形式的IP地址,转换为整数返回* 注:转换为无符号整型,如 '255.255.255.255'转为4294967295* 即: (255*256*256*256) + (255*256*256) + (255*256) + 255* @param ip 字符串格式的ip* @returns {number} 无符号整数*/
function ipaddrToNumber(ip) {//return (ip.split('.').reduce((acc, cur) => (acc << 8) + parseInt(cur), 0)) >>> 0;const ipArr = ip.split('.');if (ipArr.length !== 4)throw new Error('IP地址格式不对,应该有3个小数点');let ret = 0;// 验证每个项是否小于等于255for (let i = 0; i < 4; i++) {const number = parseInt(ipArr[i], 10);if (isNaN(number) || number > 255 || number < 0)throw new Error('IP地址中的每个项都应在0~255之间');ret = (ret << 8) + number;}// 转无符号数,避免负数返回return ret >>> 0;
}/*** 把一个无符号整数,转换为ip地址返回* @param number ipaddrToNumber方法计算得出的无符号整数* @returns {string} ip地址*/
function numberToIpAddr(number) {if (number < 0 || number > 4294967295) {throw new Error('参数应在0~4294967295之间');}const ipArr = [];for (let i = 3; i >= 0; i--) {ipArr[i] = (number >>> (8 * (3 - i))) & 255;}return ipArr.join('.');
}/*** 给定的ip,是否在给定的ip起止范围内* @param ip 要判断的ip* @param startIP ip范围起始值* @param endIp ip范围结束值* @returns {boolean} 是否在范围内*/
function inIpAddrRange(ip, startIP, endIp) {const ipNum = ipaddrToNumber(ip);const startIPNum = ipaddrToNumber(startIP);const endIPNum = ipaddrToNumber(endIp);return ipNum >= startIPNum && ipNum <= endIPNum;
}/*** 给定的ip,是否在给定的CIDR ip地址范围内* CIDR是用ip网址+子网掩码的表示法,如 192.168.0.0/16* @param ip 要判断的ip* @param startIP ip网址起始值* @param ipMaskNum 子网掩码* @returns {boolean} 是否在范围内*/
function inIpAddrCIDR(ip, startIP, ipMaskNum) {const ipMask = parseInt(ipMaskNum, 10);if (isNaN(ipMask) || ipMask < 1 || ipMask > 32)throw new Error('子网掩码应在1~32之间');const ipNum = ipaddrToNumber(ip);const startIPNum = ipaddrToNumber(startIP);const endIPNum = startIPNum + (Math.pow(2, 32 - ipMask) - 1);console.log(startIPNum + ':' + endIPNum);return ipNum >= startIPNum && ipNum <= endIPNum;
}
测试代码:
isPrivateIpAddr('192.168.0.1')
结果为 true
ipaddrToNumber('192.168.0.1')
结果为 3232235521
ipaddrToNumber('1.2.3.4')
结果为 16909060
ipaddrToNumber('255.255.255.255')
结果为 4294967295
MySQL的代码
查了一下官方文档,发现MySQL内置了 ip 和 number 互转的函数,文档链接:
SELECT INET_ATON('192.168.0.1') ip1,INET_ATON('1.2.3.4') ip2, INET_ATON('255.255.255.255') ip3, INET_NTOA(16909060) ip4;
上面sql得到的结果如下:
ip1 | ip2 | ip3 | ip4 |
---|---|---|---|
3232235521 | 16909060 | 4294967295 | 1.2.3.4 |
跟上面Javascript代码的结果是一致的。
我们只要把私有地址写入一张表,再把某个ip转数字后,去这张表查询是否有范围内的记录即可。
- 建表:
CREATE TABLE `sysprivateips` (`id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',`ipStart` varchar(50) COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT 'ip段起始值',`ipEnd` varchar(50) COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT 'ip段结束值',`ipMask` tinyint NOT NULL DEFAULT '0' COMMENT '掩码,暂时未用',`createTime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`ipStartNum` bigint GENERATED ALWAYS AS (inet_aton(`ipStart`)) VIRTUAL,`ipEndNum` bigint GENERATED ALWAYS AS (inet_aton(`ipEnd`)) VIRTUAL,PRIMARY KEY (`id`),UNIQUE KEY `uqi_ip` (`ipStartNum`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci ROW_FORMAT=DYNAMIC COMMENT='私有ip列表'
- 插入所有的私有IP数据:
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('0.0.0.0', '0.255.255.255', '8');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('10.0.0.0', '10.255.255.255', '8');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('100.64.0.0', '100.127.255.255', '10');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('127.0.0.0', '127.255.255.255', '8');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('169.254.0.0', '169.254.255.255', '16');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('172.16.0.0', '172.31.255.255', '12');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('192.0.0.0', '192.0.0.255', '24');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('192.0.2.0', '192.0.2.255', '24');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('192.88.99.0', '192.88.99.255', '24');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('192.168.0.0', '192.168.255.255', '16');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('198.18.0.0', '198.19.255.255', '15');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('198.51.100.0', '198.51.100.255', '24');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('203.0.113.0', '203.0.113.255', '24');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('224.0.0.0', '239.255.255.255', '4');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('233.252.0.0', '233.252.0.255', '24');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('240.0.0.0', '255.255.255.254', '4');
INSERT INTO `sysprivateips`(`ipStart`,`ipEnd`,`ipMask`)VALUES('255.255.255.255', '255.255.255.254', '32');
- OK,现在可以直接用sql,判断是否私有IP了:
假设要查看 192.168.0.1对应的CIDR地址段,用这个sql:
SELECT CONCAT(ipStart, '/', ipMask) AS CIDR FROM `sysprivateips`WHERE ipStartNum<=INET_ATON('192.168.0.1') AND INET_ATON('192.168.0.1')<=ipEndNum
相关文章:

互联网私有IP地址列表
最近因为业务需要,要判断用户的IP是否私有IP, 以前知道的私有IP,基本上只有如下几个(注意:这不是正确答案): 10.0.0.0/8(10.0.0.0-10.255.255.255)172.16.0.0/12(172.16.0.0-172.31…...

光伏项目管理软件为什么那么多光伏人在用?
在光伏行业迅速发展的今天,光伏项目管理软件已成为众多光伏从业者不可或缺的得力助手。那么,为何这款软件能够受到如此广泛的青睐和应用呢? 一、提高项目管理效率 光伏项目管理软件通过数字化、智能化的手段,对光伏项目的各个环节…...
《AOP实战》— 自定义注解
承接上文(传送门 —>《面试必考》 — AOP-CSDN博客),在被面试官拷打的时候,会被问到一个致命问题:“你了解aop吗?有具体的使用经验吗?” 你:......... 言尽于此,此篇…...
微前端架构下的单页应用实现策略
随着Web应用的复杂性日益增加,传统的多页应用(MPA)模式已经难以满足现代Web开发的需求。单页应用(SPA)以其流畅的用户体验和高效的页面加载速度,逐渐成为Web开发的主流模式。然而,在微前端架构下…...
JWT(JSON Web Token)工作原理及特点
JWT定义 概念:JWT是一种开放标准(RFC 7519),用于在网络上安全传输信息,常用于身份验证。比喻:类似于电子通行证,包含用户身份信息,用于身份验证和享受服务。 JWT组成部分 头部&am…...

【体检】程序人生之健康检查,全身体检与预防疫苗,五大传染病普筛,基因检测等
程序员养生指南之 【体检】程序人生之健康检查,全身体检项目分类,五大传染病普筛,基因检测等 文章目录 一、全身体检与预防疫苗(年检)1、实验室检测:生化全套检查2、医技检查:辅助诊疗科室3、科…...
汇编语言中的指令锁定:解锁高效并发编程
标题:汇编语言中的指令锁定:解锁高效并发编程 在汇编语言的微观世界中,指令锁定(Instruction Locking)是一种确保数据一致性和操作原子性的关键机制。通过使用特定的lock前缀,开发者可以告诉CPU在执行多处…...
《人工智能时代:金融投资决策的潜在系统性风险及防范策略》
在当今数字化飞速发展的时代,人工智能(AI)在金融领域的应用日益广泛,特别是在投资决策方面展现出了巨大的潜力。然而,随着其影响力的不断扩大,我们也必须警惕潜在的系统性风险。 人工智能在金融投资决策中…...

MT7621+MT7915(MT7905)+MT7975 (W7621A6G-SDK)编译固件与升级固件方法
一、搭建开发环境,编译固件。 1、安装在Ubuntu 14.04.5 x86_64系统后,然后安装下面命令行。 $ sudo apt-get install git g make libncurses5-dev subversion libssl-dev gawk libxml-parser-perl unzip wget python xz-utils vim zlibc zlib1g zlib1g…...
[php:\\filter]
写入 #题目 <?php $filename$_GET[filename]; $content$_POST[content]; file_put_contents($filename,<?php exit();.$content); highlight_file(__FILE__); ?> 源码如上,需要再服务器上写入一句话木马 payload如下: #<?php phpinf…...
Linux-环境变量
文章目录 第6章 Linux 环境变量6.1 环境变量简介?6.2 全局变量6.3 局部环境变量6.4 设置用户自定义变量6.4.1 设置局部用户自定义变量6.4.2 设置全局环境变量6.4.3 删除环境变量 6.5 默认的shell环境变量6.6 设置PATH环境变量6.7 定位系统环境变量6.7.1 登录shell6.…...
DISCUZ论坛中 “阅读权限10“这几个字的修改教程以及后台目录路径修改后的管理路径
第一篇:修改“阅读权限10”这几个字 首先找到目录: source\language\lang_message.php 找到这个文件 查找: thread_nopermission 首发地址:玖毅论坛 第二篇:后台管理路径 看到好多人在网上问discuz管理路径怎么…...
springboot 整合spring-boot-starter-data-elasticsearch
依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId></dependency> 配置 spring:elasticsearch:rest:uris: "http://localhost:9200" # Elastics…...

Element UI中el-dialog作为子组件如何由父组件控制显示/隐藏~
1、这里介绍的是将el-dialog作为组件封装便于复用,如何通过父组件控制子组件dialog的显示与隐藏。 2、思路:首先el-dialog是通过dialogVisible的值是否为true或false来控制显示与隐藏的。那么我们可以通过父传子props来将true(即showFlag的值࿰…...

【vue讲解:es6导入导出语法、 vue-router简单使用、登录跳转案例、scoped的使用、elementui使用】
1 es6导入导出语法 # 做项目:肯定要写模块--》导入使用# 默认导出和导入 在某个js中 # 命名导出和导入1.1 默认导出和导入 // #########导出语法########### // export default name // 只导出变量 // export default add // 只导出函数// export default {nam…...

#beego的orm一直引入失败#
在导入beego的orm的时候,一直导入失败,orm显示红色,表示导入失败 解决办法: 1:升级go,由1.7升级到1.8 2:执行以下命令 go clean go get github.com/astaxie/beego/orm go mod tidy go mod vendor 3:测试在vendor中可以看到…...

Vue插值:双大括号标签、v-text、v-html、v-bind 指令
创建应用程序实例后,需要通过插值进行数据绑定。数据绑定是 Vue.js 最核心的一个特性。建立数据绑定后,数据和视图会相互关联,当数据发生变化时,视图会自动进行更新。这样就无须手动获取 DOM 的值,使代码更加简洁&…...

实验五之用Processing绘画
1.案例代码如下: import generativedesign.*; import processing.pdf.*; import java.util.Calendar; Tablet tablet; boolean recordPDF false; float x 0, y 0; float stepSize 5.0; PFont font; String letters "Sie hren nicht die folgenden Gesnge…...

Apache CloudStack Official Document 翻译节选(七)
关于 Apache CloudStack 的 最佳实践 (一) Best Practices 部署Apache CloudStack是极具挑战性的,在整个部署过程中需要你做出形形色色的技术性选择。Apache CloudStack的配置条目是相当灵活的,这是因为在组合和配置具体条目时有…...

动态创建 Delphi 按钮的完整指南:基于配置文件的 `TGridPanel` 实现
在 Delphi 开发中,我们经常需要根据不同的配置动态生成 UI 元素。本文将带你通过一个完整的示例,演示如何根据配置文件动态创建按钮,并将它们排列在一个 TGridPanel 中。每个按钮的标题、链接、颜色和大小都将从配置文件中读取。 “C:\myApp\…...

网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...

华为云AI开发平台ModelArts
华为云ModelArts:重塑AI开发流程的“智能引擎”与“创新加速器”! 在人工智能浪潮席卷全球的2025年,企业拥抱AI的意愿空前高涨,但技术门槛高、流程复杂、资源投入巨大的现实,却让许多创新构想止步于实验室。数据科学家…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
Rapidio门铃消息FIFO溢出机制
关于RapidIO门铃消息FIFO的溢出机制及其与中断抖动的关系,以下是深入解析: 门铃FIFO溢出的本质 在RapidIO系统中,门铃消息FIFO是硬件控制器内部的缓冲区,用于临时存储接收到的门铃消息(Doorbell Message)。…...
Hive 存储格式深度解析:从 TextFile 到 ORC,如何选对数据存储方案?
在大数据处理领域,Hive 作为 Hadoop 生态中重要的数据仓库工具,其存储格式的选择直接影响数据存储成本、查询效率和计算资源消耗。面对 TextFile、SequenceFile、Parquet、RCFile、ORC 等多种存储格式,很多开发者常常陷入选择困境。本文将从底…...
智能AI电话机器人系统的识别能力现状与发展水平
一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...

面向无人机海岸带生态系统监测的语义分割基准数据集
描述:海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而,目前该领域仍面临一个挑战,即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...