• vtun 建立隧道的套接字和传输截获包的套接字


    认证即隧道的建立用TCP套接字,之后根据配置文件选择合适协议传输。

    clinet隧道建立套接字和传输套接字替换

    1、在clinet函数中

    s = socket(AF_INET,SOCK_STREAM,0);

    setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));

    bind(s,(struct sockaddr *)&my_addr,sizeof(my_addr)) ;

    2、在connect_t函数中

    fcntl(s,F_SETFL,O_NONBLOCK);

    connect(s,svr,sizeof(struct sockaddr);

    select(s+1,NULL,&fdset,NULL,timeout?&tv:NULL);

    fcntl(s,F_SETFL,sock_flags);

    3、在auth_client中

    readn_t(fd, buf, VTUN_MESG_SIZE, vtun.timeout);

    print_p(fd,"HOST: %s\n",host->host);//print_p向server发送认证信息。

    host->rmt_fd = s;    //这里的host->rmt_fd是TCP socket.

    4、认证成功后

    如果传输数据用UDP协议,在udp_session中,用UDP socket替换TCP socket.

    s=socket(AF_INET,SOCK_DGRAM,0)

    setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));

    bind(s,(struct sockaddr *)&saddr,sizeof(saddr)

    write_n(host->rmt_fd,(char *)&port,sizeof(short)

    readn_t(host->rmt_fd,&port,sizeof(short),host->timeout)

    connect(s,(struct sockaddr *)&saddr,sizeof(saddr))

    host->rmt_fd = s;    //这里的host->rmt_fd是UDP socket

    后续数据传输是对该套接字操作。

     

    如果传输数据用TCP协议,在tunnel函数中,继续使用该TCP socket.

    setsockopt(host->rmt_fd,SOL_SOCKET,SO_KEEPALIVE,&opt,sizeof(opt) );

    setsockopt(host->rmt_fd,IPPROTO_TCP,TCP_NODELAY,&opt,sizeof(opt) );

     

     

    server隧道建立套接字和传输套接字替换

    1、listerner函数中

    s=socket(AF_INET,SOCK_STREAM,0);

    setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));

    bind(s,(struct sockaddr *)&my_addr,sizeof(my_addr));

    listen(s, 10);

    accept(s,(struct sockaddr *)&cl_addr,&opt);

    2、auth_server函数中

    readn_t(fd, buf, VTUN_MESG_SIZE, vtun.timeout)

    print_p(fd,"OK CHAL: %s\n", cl2cs(chal_req));

    3、认证成功后

    如果传输数据用UDP协议,在udp_session中,用UDP socket替换TCP socket.

    s=socket(AF_INET,SOCK_DGRAM,0)

    setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));

    bind(s,(struct sockaddr *)&saddr,sizeof(saddr)

    write_n(host->rmt_fd,(char *)&port,sizeof(short)

    readn_t(host->rmt_fd,&port,sizeof(short),host->timeout)

    connect(s,(struct sockaddr *)&saddr,sizeof(saddr))

    host->rmt_fd = s;    //这里的host->rmt_fd是UDP socket

    后续数据传输是对该套接字操作。

     

    如果传输数据用TCP协议,在tunnel函数中,继续使用该TCP socket.

    setsockopt(host->rmt_fd,SOL_SOCKET,SO_KEEPALIVE,&opt,sizeof(opt) );

    setsockopt(host->rmt_fd,IPPROTO_TCP,TCP_NODELAY,&opt,sizeof(opt) );

  • 相关阅读:
    Tomcat环境的搭建(web基础学习笔记一)
    子查询二(在HAVING子句中使用子查询)
    子查询一(WHERE中的子查询)
    分组统计查询(学习笔记)
    Oracle体系结构一(学习笔记)
    表分区(学习笔记)
    索引(学习笔记)
    序列(学习笔记)
    触发器七(复合触发器)(学习笔记)
    触发器六(系统触发器)(学习笔记)
  • 原文地址:https://www.cnblogs.com/helloweworld/p/2705736.html
Copyright © 2020-2023  润新知