Linux下C语言检测IP地址和Mac地址是否合法

转载地址1  转载地址2  转载地址3 

检测IP参考地址_正则表达式

检测IP_正则表达式办法

1,检测IP算法,接口说明也如下图。

/*
*brief 
*param: the ip address
*return value: if susscess,0 is returned,or 1 is returned on error.
*/
int checkValidIP(const char *ipaddr)
{
    char str[31], temp[31];
    int a, b, c, d;

    if (sscanf(ipaddr, "%d.%d.%d.%d ", &a, &b, &c, &d) == 4 && a >= 0 && a <= 255 && b >= 0 && b <= 255 && c >= 0 && c <= 255 && d >= 0 && d <= 255)
    {
        sprintf(temp, "%d.%d.%d.%d", a, b, c, d); //把格式化的数据写入字符串temp
        if (strcmp(temp, ipaddr) == 0)
        {
            return 0; //success
        }
        else
        {
            return 1;
        }
    }
    else
    {
        return 1;
    }

    return 0;
}

2,检测Mac算法,接口说明也如下图。

MAC(Media Access Control或者Medium Access Control)地址,意译为媒体访问控制,或称为物理地址、硬件地址,用来定义网络设备的位置。在OSI模型中,第三层网络层负责 IP地址,第二层数据链路层则负责 MAC地址。MAC地址是网卡决定的,是固定的。因此一个主机会有一个MAC地址,而每个网络位置会有一个专属于它的IP地址。为确保MAC地址的唯一性,以太网卡制造商将MAC地址固化到网卡中。地址的前半部分(24位)标识网卡的制造商,由IEEE分配,称为OUI(组织唯一标识符);地址的后半部分由网卡制造商为其网卡分配一个唯一的编号。MAC地址为电脑网卡的物理地址,每个网卡拥有全球唯一的MAC,以示区别。格式通常为6个字节的二进制代码(以6组16进制数表示,共占6个字节),格式为XX-XX-XX-XX-XX-XX 或者 XX:XX:XX:XX:XX:XX 比如: ED-DD-4D-45-5A-9F

在一些使用MAC地址的场合中,需要对MAC地址进行合法性检测,以下提示C和JAVA两种检测方法,原理基本一致,都是使用正则表达式进行匹配:

匹配模式:"^([A-Fa-f0-9]{2}[-,:]){5}[A-Fa-f0-9]{2}$"

^ 代表开头

[A-Fa-f0-9]{2}  表示由两个16进进字符制组成 

[-,:] 分隔符可能 为 " : "或 " - "

{5} 前面由5个类似格式的字段组成,即 5个 XX- 或 XX:

[A-Fa-f0-9]{2} 表示由两个16进进字符制组成结尾

/*
*brief 
*param: pattern,正则表达式字符串;value,the mac address.
*return value: if susscess,0 is returned,or 1 is returned on error.
*/
int ereg(char *pattern, char *value)
{
    int r, cflags = 0;
    regmatch_t pm[10];
    const size_t nmatch = 10;
    regex_t reg;

    r = regcomp(&reg, pattern, cflags);
    if (r == 0)
    {
        r = regexec(&reg, value, nmatch, pm, cflags);
    }
    regfree(&reg);

    return r;
}
/*
*brief check whether the mac address is format-right
*param: the mac address
*return value: if susscess,0 is returned,or 1 is returned on error.
*/
int isValidMac(char *macaddr)
{
    int r;
    char reg[1024] = {"^[a-f0-9A-F]\\([a-f0-9A-F]\\:[a-f0-9A-F]\\)\\{5\\}[a-f0-9A-F]$"};
    r = ereg(reg, macaddr);
    return r;
}

 

#include <stdio.h>
#include <sys/types.h>
#include <regex.h>
 
 
int is_valid_mac_addr(char* mac) { 
   
	int status;
	const char * pattern = "^([A-Fa-f0-9]{2}[-,:]){5}[A-Fa-f0-9]{2}$";
	const int cflags = REG_EXTENDED | REG_NEWLINE;	
	
	char ebuf[128];
	regmatch_t pmatch[1];
	int nmatch = 10;
	regex_t reg;
 
 
	status = regcomp(&reg, pattern, cflags);//编译正则模式
	if(status != 0) {
		regerror(status, &reg, ebuf, sizeof(ebuf));
		fprintf(stderr, "regcomp fail: %s , pattern '%s' \n",ebuf, pattern);
		goto failed;
	}
 
	status = regexec(&reg, mac, nmatch, pmatch,0);//执行正则表达式和缓存的比较,
	if(status != 0) {
		regerror(status, &reg, ebuf, sizeof(ebuf));
		fprintf(stderr, "regexec fail: %s , mac:\"%s\" \n", ebuf, mac);
		goto failed;
	}
 
	printf("[%s] match success.\n", __FUNCTION__);
	regfree(&reg);
	return 0;
 
failed:
	regfree(&reg);
	return -1;
}

3,相关库函数—— regcomp regexec讲解 参考链接

https://blog.csdn.net/tanghaiyu777/article/details/65444332

https://www.cnblogs.com/274914765qq/p/4574367.html

https://www.cnblogs.com/lifan3a/articles/7536749.html

https://www.cnblogs.com/catgatp/p/8052556.html

4,正则表达式介绍:

http://www.runoob.com/regexp/regexp-syntax.html

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用C语言IP地址合法性进行判断,可以使用正则表达式或者字符串处理函数进行校验。以下是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdbool.h> bool isValidIPAddress(const char* ipAddress) { // 分割IP地址 char* token = strtok(ipAddress, "."); int num; // 检查每个分割的部分是否合法的数字 while (token != NULL) { num = atoi(token); if (num < 0 || num > 255) { return false; } // 检查数字前后是否有多余的0 char temp[4]; sprintf(temp, "%d", num); if (strcmp(temp, token) != 0) { return false; } token = strtok(NULL, "."); } return true; } int main() { const char* ipAddress = "192.168.0.1"; if (isValidIPAddress(ipAddress)) { printf("IP地址合法\n"); } else { printf("IP地址合法\n"); } return 0; } ``` 要使用C语言对子网掩码进行合法性判断,可以使用与IP地址类似的方法,检查每个分割部分是否是0或者255,并且检查位数是否正确。以下是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdbool.h> bool isValidSubnetMask(const char* subnetMask) { // 分割子网掩码 char* token = strtok(subnetMask, "."); int num; bool allOnes = false; // 检查每个分割的部分是否合法的数字 while (token != NULL) { num = atoi(token); if (num < 0 || num > 255) { return false; } // 检查数字前后是否有多余的0 char temp[4]; sprintf(temp, "%d", num); if (strcmp(temp, token) != 0) { return false; } // 检查位数是否正确 if (!allOnes && num != 255) { if (num == 0) { allOnes = true; } else { return false; } } else if (allOnes && num != 0) { return false; } token = strtok(NULL, "."); } return true; } int main() { const char* subnetMask = "255.255.255.0"; if (isValidSubnetMask(subnetMask)) { printf("子网掩码合法\n"); } else { printf("子网掩码合法\n"); } return 0; } ``` 这些示例代码仅供参考,具体的判断逻辑可以根据实际需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值