GATEWAY获取与设置(Linux C)

GATEWAY获取与设置(Linux C)

#include <sys/types.h>  
#include <sys/socket.h>  
#include <netinet/in.h>  
#include <net/if.h>  
#include <sys/ioctl.h>  
#include <errno.h>  
#include <string.h>  
#include <net/route.h>  
#include <unistd.h>  
#include <stdio.h>  

int set_gateway(unsigned long gw)     
{     
int skfd;     
struct rtentry rt;     
int err;     

  skfd = socket(PF_INET, SOCK_DGRAM, 0);     
if (skfd < 0)     
return -1;     

/* Delete existing defalt gateway */ 
  memset(&rt, 0, sizeof(rt));     

  rt.rt_dst.sa_family = AF_INET;     
  ((struct sockaddr_in *)&rt.rt_dst)->sin_addr.s_addr = 0;     

  rt.rt_genmask.sa_family = AF_INET;     
  ((struct sockaddr_in *)&rt.rt_genmask)->sin_addr.s_addr = 0;     

  rt.rt_flags = RTF_UP;     

  err = ioctl(skfd, SIOCDELRT, &rt);     

if ((err == 0 || errno == ESRCH) && gw) {     
/* Set default gateway */ 
  memset(&rt, 0, sizeof(rt));     

  rt.rt_dst.sa_family = AF_INET;     
  ((struct sockaddr_in *)&rt.rt_dst)->sin_addr.s_addr = 0;     

  rt.rt_gateway.sa_family = AF_INET;     
  ((struct sockaddr_in *)&rt.rt_gateway)->sin_addr.s_addr = gw;     

  rt.rt_genmask.sa_family = AF_INET;     
  ((struct sockaddr_in *)&rt.rt_genmask)- >sin_addr.s_addr = 0;     

  rt.rt_flags = RTF_UP | RTF_GATEWAY;     

  err = ioctl(skfd, SIOCADDRT, &rt);     
 }     

  close(skfd);     

return err;     
}     

int get_gateway(unsigned long *p)     
{     
FILE *fp;     
char buf[256]; // 128 is enough for linux  
char iface[16];     
  unsigned long dest_addr, gate_addr;     
  *p = INADDR_NONE;     
  fp = fopen("/proc/net/route", "r");     
if (fp == NULL)     
return -1;     
/* Skip title line */ 
  fgets(buf, sizeof(buf), fp);     
while (fgets(buf, sizeof(buf), fp)) {     
if (sscanf(buf, "%s\t%lX\t%lX", iface,       &dest_addr, &gate_addr) != 3 ||     
  dest_addr != 0)     
continue;     
  *p = gate_addr;     
break;     
  }     

  fclose(fp);     
return 0;     
}   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用C语言编写程序来获取Linux系统的路由表。在Linux系统中,可以使用`netlink`套接字来与内核通信,并通过`rtnetlink`协议获取路由表信息。 下面是一个简单的示例代码,可以获取并打印路由表的信息: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/socket.h> #include <linux/netlink.h> #include <linux/rtnetlink.h> #define BUF_SIZE 8192 int main() { int sock; struct sockaddr_nl sa; struct nlmsghdr *nlh; char buf[BUF_SIZE]; // 创建netlink套接字 sock = socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE); if (sock < 0) { perror("socket"); return -1; } // 设置netlink套接字地址 memset(&sa, 0, sizeof(sa)); sa.nl_family = AF_NETLINK; sa.nl_groups = RTMGRP_IPV4_ROUTE; // 绑定套接字 if (bind(sock, (struct sockaddr*)&sa, sizeof(sa)) < 0) { perror("bind"); close(sock); return -1; } // 构造请求消息 nlh = (struct nlmsghdr*)buf; memset(nlh, 0, sizeof(struct nlmsghdr)); nlh->nlmsg_len = NLMSG_LENGTH(sizeof(struct rtmsg)); nlh->nlmsg_type = RTM_GETROUTE; nlh->nlmsg_flags = NLM_F_REQUEST | NLM_F_DUMP; nlh->nlmsg_seq = 1; nlh->nlmsg_pid = getpid(); // 发送请求消息 if (send(sock, nlh, nlh->nlmsg_len, 0) < 0) { perror("send"); close(sock); return -1; } // 接收并处理回复消息 while (1) { int len = recv(sock, buf, BUF_SIZE, 0); if (len < 0) { perror("recv"); close(sock); return -1; } // 解析回复消息 struct nlmsghdr* nh; for (nh = (struct nlmsghdr*)buf; NLMSG_OK(nh, len); nh = NLMSG_NEXT(nh, len)) { if (nh->nlmsg_type == NLMSG_DONE) { break; } if (nh->nlmsg_type == NLMSG_ERROR) { perror("Netlink error"); close(sock); return -1; } // 获取路由表项信息 struct rtmsg *rtm = (struct rtmsg*)NLMSG_DATA(nh); struct rtattr *attr = (struct rtattr*)RTM_RTA(rtm); int attrlen = RTM_PAYLOAD(nh); while (RTA_OK(attr, attrlen)) { if (attr->rta_type == RTA_DST) { struct in_addr dst; memcpy(&dst, RTA_DATA(attr), sizeof(struct in_addr)); printf("Destination: %s\n", inet_ntoa(dst)); } if (attr->rta_type == RTA_GATEWAY) { struct in_addr gw; memcpy(&gw, RTA_DATA(attr), sizeof(struct in_addr)); printf("Gateway: %s\n", inet_ntoa(gw)); } if (attr->rta_type == RTA_OIF) { int ifindex = *(int*)RTA_DATA(attr); printf("Interface Index: %d\n", ifindex); } attr = RTA_NEXT(attr, attrlen); } printf("------------------------\n"); } } close(sock); return 0; } ``` 这段代码使用了`netlink`套接字来发送路由表的请求消息,并通过解析回复消息来获取路由表项的信息。你可以根据需要进一步处理这些信息。 请注意,此代码只能在Linux系统上编译和运行,并且需要具有足够的权限才能访问路由表。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值