免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1485 | 回复: 3
打印 上一主题 下一主题

FREEBSD6.0下添加路由的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-04 17:16 |只看该作者 |倒序浏览
写了个程序,但发现有问题,但不知道问题在那里,请各位大侠指教,谢谢
说下情况:编译成功,可以添加但和route add添加出来有不同
如:# route add 192.168.1.0 192.168.0.8 255.255.255.0
# netstat -rn
192.168.1          192.168.0.8        UGS         0        0   lnc0

但如果用我自己写的程序会发生下面的情况
# ./addrt 192.168.4.0 192.168.0.8 255.255.255.0
# netstat -rn
192.168.4          link#1             UC          0        0   lnc0

与route相比添加后算直连的,没有GS标记,替代的是克隆掩码

代码如下:
#include        "unproute.h"

#define BUFLEN  (sizeof(struct rt_msghdr) + 3*sizeof(struct sockaddr_in))
                                        /* sizeof(struct sockaddr_in6) * 8 = 192 */
#define SEQ             9999

int
main(int argc, char **argv)
{
        int                                     sockfd;
        char                            *buf;
        pid_t                           pid;
        struct rt_msghdr        *rtm;
        struct sockaddr_in      *sin,*sin2,*sin3;

        if (argc != 4)
                err_quit("usage: addrrt <IPaddress> <IPaddress> <netmask>");

        sockfd = Socket(AF_ROUTE, SOCK_RAW, 0); /* need superuser privileges */

        buf = Calloc(1, BUFLEN);        /* and initialized to 0 */

        rtm = (struct rt_msghdr *) buf;
        rtm->rtm_msglen = sizeof(struct rt_msghdr) + 3*sizeof(struct sockaddr_in);
        rtm->rtm_version = RTM_VERSION;
        rtm->rtm_type = RTM_ADD;
        rtm->rtm_addrs = RTA_DST | RTA_GATEWAY | RTA_NETMASK;
        rtm->rtm_pid = pid = getpid();
        rtm->rtm_seq = SEQ;

        sin = (struct sockaddr_in *) (rtm + 1);
        sin->sin_len = sizeof(struct sockaddr_in);
        sin->sin_family = AF_INET;
        Inet_pton(AF_INET, argv[1], &sin->sin_addr);

        sin2 = (struct sockaddr_in *) (sin+1);
        sin2->sin_len = sizeof(struct sockaddr_in);
        sin2->sin_family = AF_INET;
        Inet_pton(AF_INET, argv[2], &sin2->sin_addr);

        sin3 = (struct sockaddr_in *) (sin2+1);
        sin3->sin_len = sizeof(struct sockaddr_in);
        sin3->sin_family = AF_INET;
        Inet_pton(AF_INET, argv[3], &sin3->sin_addr);

        Write(sockfd, rtm, rtm->rtm_msglen);
}

论坛徽章:
0
2 [报告]
发表于 2009-05-04 20:15 |只看该作者
忘记讲了
如果是单个IP,那么就会显示网关,但标记还是不正确
# ./addrt 192.168.4.10 192.168.0.8 255.255.255.255
# netstat -rn
192.168.4.10/32         192.168.0.8           U          0        0   lnc0

论坛徽章:
0
3 [报告]
发表于 2009-05-05 10:45 |只看该作者
基本上把问题定在netmask写入方面,掩码不是用sockaddr_in来写的,但我还不知道用什么来写用sockaddr?
希望大家给我个提示

论坛徽章:
0
4 [报告]
发表于 2009-05-06 10:48 |只看该作者
问题已经解决了
主要有2个问题,一个是掩码写入问题,一个是忘记写flags了,哈哈
下面贴下代码
#include        "unproute.h"

#define BUFLEN  (sizeof(struct rt_msghdr) + 512)

#define SEQ             9999

int
main(int argc, char **argv)
{
        int                                     sockfd;
        char                            *buf;
        pid_t                           pid;
        struct rt_msghdr        *rtm;
        struct sockaddr_in      *sin,*sin2;
        struct sockaddr         sin3;
        if (argc != 4)
                err_quit("usage: addrrt <IPaddress> <gw> <netmask>");

        sockfd = Socket(AF_ROUTE, SOCK_RAW, 0); /* need superuser privileges */

        buf = Calloc(1, BUFLEN);        /* and initialized to 0 */

        rtm = (struct rt_msghdr *) buf;
        rtm->rtm_msglen = sizeof(struct rt_msghdr) + 2*sizeof(struct sockaddr_in)+sizeof(struct sockaddr);
        rtm->rtm_version = RTM_VERSION;
        rtm->rtm_type = RTM_ADD;
        rtm->rtm_flags=RTF_UP | RTF_GATEWAY |RTF_STATIC;
        rtm->rtm_addrs = RTA_DST | RTA_GATEWAY | RTA_NETMASK;
        rtm->rtm_pid = pid = getpid();
        rtm->rtm_seq = SEQ;

        sin = (struct sockaddr_in *) (rtm + 1);
        sin->sin_len = sizeof(struct sockaddr_in);
        sin->sin_family = AF_INET;
        Inet_pton(AF_INET, argv[1], &sin->sin_addr);

        sin2 = (struct sockaddr_in *) (sin+1);
        sin2->sin_len = sizeof(struct sockaddr_in);
        sin2->sin_family = AF_INET;
        Inet_pton(AF_INET, argv[2], &sin2->sin_addr);

        sin3 = (struct sockaddr *) (sin2+1);
        sin3->sa_len=8;
        Inet_pton(AF_INET,argv[3],&sin3->sa_data[2]);
        Write(sockfd, rtm, rtm->rtm_msglen);

        exit(0);
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP