GO语言判断一个网段是否属于另一个网段的子网

目录
  • 1.校验网段是否合法
    • 1.1函数
    • 1.2分析
    • 1.3主函数运行测试
  • 2.校验ip是否合法
    • 2.1函数
    • 2.2分析
    • 2.3主函数运行测试
  • 3.判断两个网段,一个是否是另一个的子网
    • 3.1函数
    • 3.2分析
    • 3.3运行测试

1.校验网段是否合法

1.1函数

import (
    "fmt"
    "net"
)
func IsNetWorkOk(network string ) bool{
    _, _, err := net.ParseCIDR(network)
    if err != nil {
        return false
    }
    return true
}

1.2分析

第一步就是先split变成ip跟子网掩码

主要原理就是变成二进制以后再进行判断

ipv4跟ipv6都可以校验,如果只想校验ipv4可以调用parseIPv4方法

1.3主函数运行测试

func main() {
    ip := "100.4.11.3/24"
    result := IsNetWorkOk(ip)
    fmt.Println(result)
}

2.校验ip是否合法

2.1函数

func IsIpOk(ip string ) bool{
    address := net.ParseIP(ip)
    if address == nil {
        return false
    }
    return true
}

2.2分析

点分十进制换成2进制,判断是否合法:

2.3主函数运行测试

func main() {
    ip := "100.4.11.34"
    result := IsIpOk(ip)
    fmt.Println(result)
}

3.判断两个网段,一个是否是另一个的子网

3.1函数

func ContainsCIDR(a, b *net.IPNet) bool {
    ones1, _ := a.Mask.Size()
    ones2, _ := b.Mask.Size()
    return ones1 <= ones2 && a.Contains(b.IP)
}

//最好提前做好网段是否合法校验
func ContainsCIDRString(a,b string)(bool,error){
    _, net1, err := net.ParseCIDR(a)
    if err != nil {
        return false,err
    }
    _, net2, err := net.ParseCIDR(b)
    if err != nil {
        return false,err
    }
    result := ContainsCIDR(net1,net2)
    return result,err
}

3.2分析

调用了ip包含的方法

3.3运行测试

func main() {
    net1 := "100.64.0.0/16"
    net2 := "100.64.0.0/20"
    _, a, err := net.ParseCIDR(net1)
    _, b, err := net.ParseCIDR(net2)
    if err != nil {
        return
    }
    result := ContainsCIDR(a,b)
    fmt.Println(result)
}

到此这篇关于GO语言判断一个网段是否属于另一个网段的子网的文章就介绍到这了,更多相关golang网段内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Golang 并发下的问题定位及解决方案

    目录 问题描述 解决方案 实现思路 2.1通过栈信息解析后获取 2.2修改Go源码获取 2.3通过CGO获取 问题描述 在使用 gin-swagger 的过程中, 经常会发生因为缺少 json 等 tag 而导致的异常. 由于 gin-swagger 是并发执行的, 输出的日志本身是错位的. 这就导致无法定义是哪一个结构体缺少 tag 导致的. 一般而言, 这种时候只能一个个点开去检查. 解决方案 思路 : 要是每行日志带当前 goroutine_id 的话, 是不是就可以准确定位到报错的 go

  • Golang语言的多种变量声明方式与使用场景详解

    目录 01介绍 02变量声明方式 标准声明变量 不显式赋初始值声明变量 省略类型声明变量 短变量声明 显式类型转换 变量列表声明 变量声明块 03使用场景 包级变量 全局变量 局部变量 04注意事项: 05总结 01介绍 在程序设计中,编译器必须将代表数据的变量名称替换成该数据所在的内存地址.变量的名称.类型及内存地址通常会维持固定,但该内存地址所存储的数据在程序执行期间则可能会改变. Golang 语言编译器需要先明确变量的内存边界,才可以使用变量.通过声明变量使用的类型,编译器可以明确变量的

  • GO语言判断一个网段是否属于另一个网段的子网

    目录 1.校验网段是否合法 1.1函数 1.2分析 1.3主函数运行测试 2.校验ip是否合法 2.1函数 2.2分析 2.3主函数运行测试 3.判断两个网段,一个是否是另一个的子网 3.1函数 3.2分析 3.3运行测试 1.校验网段是否合法 1.1函数 import (     "fmt"     "net" ) func IsNetWorkOk(network string ) bool{     _, _, err := net.ParseCIDR(netw

  • 用C语言判断一个二叉树是否为另一个的子结构

    1.问题描述: 如何判断一个二叉树是否是另一个的子结构?      比如: 2       /   \      9    8     / \    /    2  3  5   / 6 有个子结构是    9   / \ 2  3 2.分析问题:     有关二叉树的算法问题,一般都可以通过递归来解决.那么写成一个正确的递归程序,首先一定要分析正确递归结束的条件. 拿这道题来讲,什么时候递归结束. <1>第二个二叉树root2为空时,说明root2是第一棵二叉树的root1的子结构,返回tr

  • 使用C语言判断栈的方向实例

    这一问题主要是如何判读出先后入栈的变量的地址大小,比如有a, b两个变量一先一后被定义,如果a的地址大于b的地址,则说明是以低地址方向增长的,反之,往高地址方向增长.在写C程序的时候不能简单直接的定义两个变量来比较它们的地址大小,因为这样很有可能编译器会做优化,最终导致结果不真实.为避免这种编译器优化的情况,可以采用将变量定义到函数中,然后递归调用该函数. 例如下面的代码: #include <stdio.h> static int stack_direction = 0; static vo

  • C语言判断一个数是否为素数方法解析

    一.概念介绍 素数又称为质数.一个大于1的自然数(从2开始),除了1和它本身外,不能被其他自然数整除的叫做素数,否则称为合数. 0和1既不是素数也不是合数,最小的素数是2. 二.代码 方法一: bool is_Prime(int num){ int i; for(i = 2;i <= sqrt(num);i++){ if(num % i == 0)//一旦发现有因子,则返回false return false; } return true; } 注意:在for循环判断时不能忘记 i <= sq

  • R语言判断语句的使用详解

    判断结构要求程序员指定一个或多个要评估或测试的条件,以及条件为真时要执行的语句(必需的)和条件为假时要执行的语句(可选的). 下面是大多数编程语言中典型的判断结构的一般形式: R 语言提供了以下类型的判断语句: if 语句 if...else 语句 switch 语句 if 语句 一个 if 语句 由一个布尔表达式后跟一个或多个语句组成. 语法格式如下: if(boolean_expression) { // 布尔表达式为真将执行的语句 } 如果布尔表达式 boolean_expression

  • C语言判断数是否为素数与素数输出

    目录 1.判断单个数是否为素数(多组输入) 2.输入范围输出范围内的素数 3.总结 素数的概念:素数也叫质数,是一种只能被自己本身和1整除的数并且大于1,当然0与1不是素数. 1.判断单个数是否为素数(多组输入) 我的思路是,首先输入一个数,利用素数的概念来判断是非为素数,是的话输出素数:否则不输出. 关于素数的判断首先我们吧输入的数当初被除数,我选择用一个for循环来实现,从2开始当除数,每轮加1,一直循环去除被除数,一直除到被除数减一那个数,要是期间能被一个数整除则跳出循环不为素数,要是一直

  • 利用go语言判断是否是完全二叉树

    目录 一.什么是完全二叉树? 二.流程 三.代码 1.树节点 2.测试代码 3.判断树是否为完全二叉树代码 4.代码解读 5.运行结果 一.什么是完全二叉树? 先看如下这一张图: 这个一颗二叉树,如何区分该树是不是完全二叉树呢? 当一个节点存在右子节点但是不存在左子节点这颗树视为非完全二叉树 当一个节点的左子节点存在但是右子节点不存在视为完全二叉树 如果没有子节点,那也是要在左侧开始到右侧依次没有子节点才视为完全二叉树,就像上图2中 而上面第一张图这颗二叉树很明显是一颗非完全二叉树,因为在第三层

  • Go语言判断指定文件是否存在的方法

    本文实例讲述了Go语言判断指定文件是否存在的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: package main    import (     "fmt"     "os" )    func main() {     f, err := os.Open("dotcoo.com.txt")     if err != nil && os.IsNotExist(err) {         fmt.Pri

  • Javascript 判断两个IP是否在同一网段实例代码

    Javascript 判断两个IP是否在同一网段 以下脚本不做IP格式的判断,只判断两个IP是否在同一网段. 例子,Javascript判断两个IP是否在同一网段. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> IP段信息检测_www.manongjc.com </TITLE> <script la

  • js判断一个元素是否为另一个元素的子元素的代码

    当然方法有很多,不过个人认为通过判断一个元素是否为另一个元素的子元素是最简单的实现方式之一. 废话少说直接上方法: 复制代码 代码如下: function isParent (obj,parentObj){ while (obj != undefined && obj != null && obj.tagName.toUpperCase() != 'BODY'){ if (obj == parentObj){ return true; } obj = obj.parentN

随机推荐