亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mcastv3.cpp

?? < WINDOWS網絡編程>>英文版,一本詳細講解WINDOWS平臺下網絡編程的國外經典書籍,適合英文水平高的牛人
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
        rc = WSAIoctl(
                s,
                SIO_SET_MULTICAST_FILTER,
                filterbuf,
                filterlen,
                NULL,
                0,
               &bytes,
                NULL,
                NULL
                );
        if (rc == SOCKET_ERROR)
        {
            fprintf(stderr, "JoinMulticastGroup: WSAIoctl: SIO_SET_MULTICAST_FILTER failed: %d\n",
                    WSAGetLastError());
            return SOCKET_ERROR;
        }
    }

    return NO_ERROR;
}

// 
// Function: GetMulticastState
// 
// Description:
//    Obtains the current multicat filter state and prints it to the console.
//
void GetMulticastState(SOCKET s, struct addrinfo *group, struct addrinfo *iface)
{
    struct ip_msfilter *filter=NULL;
    char                buf[15000];
    int                 buflen=15000,
                        rc,
                        i;

    filter = (struct ip_msfilter *)buf;

    filter->imsf_multiaddr = ((SOCKADDR_IN *)group->ai_addr)->sin_addr;
    filter->imsf_interface = ((SOCKADDR_IN *)iface->ai_addr)->sin_addr;

    rc = WSAIoctl(s, SIO_GET_MULTICAST_FILTER, buf, buflen, buf, buflen, (LPDWORD)&buflen, NULL, NULL);
    if (rc == SOCKET_ERROR)
    {
        fprintf(stderr, "GetMulticastState: WSAIoctl failed: %d\n", WSAGetLastError());
        return;
    }

    printf("imsf_multiaddr = %s\n", inet_ntoa(filter->imsf_multiaddr));
    printf("imsf_interface = %s\n", inet_ntoa(filter->imsf_interface));
    printf("imsf_fmode     = %s\n", (filter->imsf_fmode == MCAST_INCLUDE ? "MCAST_INCLUDE" : "MCAST_EXCLUDE"));
    printf("imsf_numsrc    = %d\n", filter->imsf_numsrc);
    for(i=0; i < (int)filter->imsf_numsrc ;i++)
    {
        printf("imsf_slist[%d]  = %s\n", i, inet_ntoa(filter->imsf_slist[i]));
    }
    return;
}

// 
// Function: SetSendInterface
//
// Description:
//    Set the send interface for the socket.
//
int SetSendInterface(SOCKET s, struct addrinfo *iface)
{
    char *optval=NULL;
    int   optlevel,
          option,
          optlen,
          rc;

    optlevel = IPPROTO_IP;
    option   = IP_MULTICAST_IF;
    optval   = (char *) &((SOCKADDR_IN *)iface->ai_addr)->sin_addr.s_addr;
    optlen   = sizeof(((SOCKADDR_IN *)iface->ai_addr)->sin_addr.s_addr);

    rc = setsockopt(
            s, 
            optlevel, 
            option,
            optval,
            optlen
                   );
    if (rc == SOCKET_ERROR)
    {
        printf("setsockopt failed: %d\n", WSAGetLastError());
    }
    else
    {
        printf("Set sending interface to: ");
        PrintAddress(iface->ai_addr, iface->ai_addrlen);
        printf("\n");
    }
    return rc;
}

//
// Function: SetMulticastTtl
//
// Description:
//    This routine sets the multicast TTL on the socket.
//
int SetMulticastTtl(SOCKET s, int af, int ttl)
{
    char *optval=NULL;
    int   optlevel,
          option,
          optlen,
          rc;

    optlevel = IPPROTO_IP;
    option   = IP_MULTICAST_TTL;
    optval   = (char *) &ttl;
    optlen   = sizeof(ttl);

    rc = setsockopt(
            s, 
            optlevel, 
            option,
            optval, 
            optlen
            );
    if (rc == SOCKET_ERROR)
    {
        fprintf(stderr, "SetMulticastTtl: setsockopt failed: %d\n", WSAGetLastError());
    }
    else
    {
        printf("Set multicast ttl to: %d\n", ttl);
    }
    return rc;
}

// 
// Function: SetMulticastLoopBack
//
// Description:
//    This function enabled or disables multicast loopback. If loopback is enabled
//    (and the socket is a member of the destination multicast group) then the
//    data will be placed in the receive queue for the socket such that if a 
//    receive is posted on the socket its own data will be read. For this sample
//    it doesn't really matter as if invoked as the sender, no data is read.
//
int SetMulticastLoopBack(SOCKET s, int af, int loopval)
{
    char *optval=NULL;
    int   optlevel,
          option,
          optlen,
          rc;

    optlevel = IPPROTO_IP;
    option   = IP_MULTICAST_LOOP;
    optval   = (char *) &loopval;
    optlen   = sizeof(loopval);
 
    rc = setsockopt(
            s, 
            optlevel, 
            option,
            optval, 
            optlen
            );
    if (rc == SOCKET_ERROR)
    {
        fprintf(stderr, "SetMulticastLoopBack: setsockopt failed: %d\n", WSAGetLastError());
    }
    else
    {
        printf("Setting multicast loopback to: %d\n", loopval);
    }
    return rc;
}

//
// Function: main
// 
// Description:
//    Parse the command line arguments, load the Winsock library, 
//    create a socket and join the multicast group. If set as a
//    sender then begin sending messages to the multicast group;
//    otherwise, call recvfrom() to read messages send to the 
//    group.
//    
int _cdecl main(int argc, char **argv)
{
    WSADATA             wsd;
    SOCKET              s;
    struct addrinfo    *resmulti=NULL,
                       *resbind=NULL,
                       *resif=NULL;
    char               *buf;
    int                 rc,
                        i=0;

    // Parse the command line
    ValidateArgs(argc, argv);

    if ((gMode == MCAST_INCLUDE) && (gSourceCount == 0) && (!bUseFilter))
    {
        printf("\nNo sources specified!\n\n"
               "At least one source must be specified when mode is INCLUDE\n"
               "   and not using the multicast filter option (-f)\n\n");
        usage(argv[0]);
    }

    // Load Winsock
    if (WSAStartup(MAKEWORD(1, 1), &wsd) != 0)
    {
        printf("WSAStartup failed\n");
        return -1;
    }

    // Resolve the multicast address
    resmulti = ResolveAddress(gMulticast, gPort, AF_UNSPEC, gSocketType, gProtocol);
    if (resmulti == NULL)
    {
        fprintf(stderr, "Unable to convert multicast address '%s': %d\n",
                gMulticast, WSAGetLastError());
        return -1;
    }
    if (resmulti->ai_family != AF_INET)
    {
        fprintf(stderr, "Source multicasting is only supported for IPv4\n");
        return -1;
    }

    // Resolve the binding address
    resbind = ResolveAddress(gBindAddr, (bSender ? "0" : gPort), resmulti->ai_family, resmulti->ai_socktype, resmulti->ai_protocol);
    if (resbind == NULL)
    {
        fprintf(stderr, "Unable to convert bind address '%s': %d\n",
                gBindAddr, WSAGetLastError());
        return -1;
    }
    if (resbind->ai_family != AF_INET)
    {
        fprintf(stderr, "Source multicasting is only supported for IPv4\n");
        return -1;
    }

    // Resolve the multicast interface
    resif   = ResolveAddress(gInterface, "0", resmulti->ai_family, resmulti->ai_socktype, resmulti->ai_protocol);
    if (resif == NULL)
    {
        fprintf(stderr, "Unable to convert interface address '%s': %d\n",
                gInterface, WSAGetLastError());
        return -1;
    }
    if (resif->ai_family != AF_INET)
    {
        fprintf(stderr, "Source multicasting is only supported for IPv4\n");
        return -1;
    }
    // 
    // Create the socket. In Winsock 1 you don't need any special
    // flags to indicate multicasting.
    //
    s = socket(resmulti->ai_family, resmulti->ai_socktype, resmulti->ai_protocol);
    if (s == INVALID_SOCKET)
    {
        printf("socket failed with: %d\n", WSAGetLastError());
        return -1;
    }
    printf("socket handle = 0x%p\n", s);
    //
    // Bind the socket to the local interface. This is done so we
    // can receive data
    //
    rc = bind(s, resbind->ai_addr, resbind->ai_addrlen);
    if (rc == SOCKET_ERROR)
    {
        printf("bind failed: %d\n", WSAGetLastError());
        return -1;
    }
    printf("Binding to ");
    PrintAddress(resbind->ai_addr, resbind->ai_addrlen);
    printf("\n");

    if (bDontJoin == FALSE)
    {
        rc = JoinMulticastGroup(s, resmulti, resif);
        if (rc == SOCKET_ERROR)
        {
            return -1;
        }
    }

    rc = SetSendInterface(s, resif);
    if (rc == SOCKET_ERROR)
    {
        return -1;
    }

    // Set the TTL to something else. The default TTL is one.
    rc = SetMulticastTtl(s, resmulti->ai_family, gTtl);
    if (rc == SOCKET_ERROR)
    {
        return -1;
    }

    // Disable the loopback if selected. Note that on NT4 and Win95
    // you cannot disable it.
    if (bLoopBack)
    {
        rc = SetMulticastLoopBack(s, resmulti->ai_family, gLoopBack);
        if (rc == SOCKET_ERROR)
        {
            return -1;
        }
    }

    //
    // When using sendto on an IPv6 multicast socket, the scope id needs
    // to be zero.
    //
    if ((bSender) && (resmulti->ai_family == AF_INET6))
        ((SOCKADDR_IN6 *)resmulti->ai_addr)->sin6_scope_id = 0;

    if (bConnect)
    {
        rc = connect(s, resmulti->ai_addr, resmulti->ai_addrlen);
        if (rc == SOCKET_ERROR)
        {
            printf("connect failed: %d\n", WSAGetLastError());
            return -1;
        }
    }

    GetMulticastState(s, resmulti, resif);

    buf = (char *)HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, gBufferSize);
    if (buf == NULL)
    {
        fprintf(stderr, "HeapAlloc failed: %d\n", GetLastError());
        return -1;
    }

    if (!bSender)           // receiver
    {
        SOCKADDR_STORAGE safrom;
        int              fromlen;

        //
        for(i=0; i < gCount ;i++)
        {
            fromlen = sizeof(safrom);
            rc = recvfrom(
                    s, 
                    buf, 
                    gBufferSize, 
                    0,
                   (SOCKADDR *)&safrom, 
                   &fromlen
                   );
            if (rc == SOCKET_ERROR)
            {
                printf("recvfrom failed with: %d\n", 
                    WSAGetLastError());
                break;
            }

            printf("RECV %d bytes from <", rc);
            PrintAddress((SOCKADDR *)&safrom, fromlen);
            printf(">\n");
        }
    }
    else                    // sender
    {
        memset(buf, '%', gBufferSize);

        // Send some data
        for(i=0; i < gCount ; i++)
        {
            rc = sendto(
                    s, 
                    buf,
                    gBufferSize,
                    0,
                    resmulti->ai_addr,
                    resmulti->ai_addrlen
                    );
            if (rc == SOCKET_ERROR)
            {
                printf("sendto failed with: %d\n", WSAGetLastError());
                return -1;
            }

            printf("SENT %d bytes to ", rc);
            PrintAddress(resmulti->ai_addr, resmulti->ai_addrlen);
            printf("\n");

            Sleep(500);
        }
    }

    freeaddrinfo(resmulti);
    freeaddrinfo(resbind);
    freeaddrinfo(resif);

    HeapFree(GetProcessHeap(), 0, buf);
    
    closesocket(s);

    WSACleanup();
    return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区不卡| 韩国一区二区在线观看| 韩国成人精品a∨在线观看| 99久久免费精品高清特色大片| 69堂精品视频| 日本乱人伦一区| 日韩精品一区二区三区老鸭窝| 国产人成亚洲第一网站在线播放| 一区二区三区四区激情| 精品一区二区在线免费观看| 欧美调教femdomvk| ...av二区三区久久精品| 免费观看在线综合色| av亚洲精华国产精华| 2023国产精华国产精品| 亚洲一区二区3| 东方aⅴ免费观看久久av| 91精品视频网| 国产一区二区三区香蕉| 欧美一区二区三区系列电影| 一区二区在线电影| av在线播放一区二区三区| 一区二区高清免费观看影视大全 | 久久亚洲一区二区三区明星换脸 | 国产精品视频你懂的| 美国毛片一区二区| 91精品国产一区二区人妖| 国产麻豆日韩欧美久久| 亚洲激情男女视频| 日韩一区二区高清| 欧美aaaaaa午夜精品| 亚洲国产电影在线观看| 国产一区二区精品在线观看| 亚洲人成人一区二区在线观看| 不卡视频在线看| 中文字幕在线不卡一区| 日韩一区二区在线观看| 91麻豆国产在线观看| 最新国产精品久久精品| 国产成人亚洲综合a∨猫咪| 精品欧美一区二区在线观看| 国产在线精品不卡| 亚洲成a人在线观看| 欧美无人高清视频在线观看| 国产精品一区二区久久不卡| 中文无字幕一区二区三区| 欧美日韩一区二区在线观看视频| 高清国产一区二区三区| 青青草国产精品97视觉盛宴| 一区二区三区在线看| 欧美激情一区二区三区四区| 91精品国产一区二区三区| 色婷婷久久久亚洲一区二区三区 | 欧美精品高清视频| 麻豆成人免费电影| 亚洲国产日韩在线一区模特| 日韩精品一区国产麻豆| 欧美色综合网站| 国产成a人亚洲| 一区二区三区自拍| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 风间由美性色一区二区三区| 日韩精品一级二级 | 成人一区二区三区视频在线观看| 中文字幕精品在线不卡| 精品久久久久久综合日本欧美 | 欧美r级在线观看| 欧美精选在线播放| 欧美色精品天天在线观看视频| 91免费看片在线观看| 91精品办公室少妇高潮对白| 国产精品123区| 久久99国产精品免费网站| 天堂午夜影视日韩欧美一区二区| 一区二区三区影院| 中文字幕在线视频一区| 欧美色视频在线观看| 在线一区二区视频| 91久久精品一区二区二区| 色婷婷精品大在线视频| 91麻豆福利精品推荐| 91麻豆免费视频| 91久久精品网| 欧美三级中文字幕在线观看| 精品视频色一区| 在线播放欧美女士性生活| 538prom精品视频线放| 日韩精品一区二区三区蜜臀 | 精品一区二区免费| 精品一区二区三区在线播放视频| 久久99热这里只有精品| 亚洲精品欧美综合四区| 亚洲在线免费播放| 日欧美一区二区| 国产精品午夜免费| 97se狠狠狠综合亚洲狠狠| jiyouzz国产精品久久| 99精品偷自拍| 欧美中文一区二区三区| 国产一区二区精品在线观看| 国产成人精品免费在线| 成人av午夜电影| 色噜噜夜夜夜综合网| 欧美日韩成人综合在线一区二区| caoporen国产精品视频| 在线免费观看一区| 7777精品伊人久久久大香线蕉经典版下载 | 国产精品久久久久久户外露出| 国产精品成人免费 | 日本亚洲最大的色成网站www| 亚洲欧美激情一区二区| 亚洲成年人网站在线观看| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 在线一区二区三区| 91精品国产福利在线观看| 精品国产乱码久久久久久1区2区 | 精品一区二区三区av| 成人综合在线视频| 欧美网站大全在线观看| 欧美精品一区二区不卡| 一级女性全黄久久生活片免费| 日韩成人精品在线观看| 麻豆精品在线观看| 91视频免费看| ww亚洲ww在线观看国产| 亚洲蜜臀av乱码久久精品| 精品一区二区在线观看| 欧洲人成人精品| 国产女同互慰高潮91漫画| 亚洲一线二线三线久久久| 亚洲欧美在线另类| 免费成人在线视频观看| 国内精品免费**视频| 国产激情精品久久久第一区二区 | 97se亚洲国产综合自在线| 欧美丰满少妇xxxxx高潮对白| 国产欧美日韩视频在线观看| 午夜一区二区三区视频| 亚洲一级二级在线| 国产成人精品免费| 91精品国产综合久久久久| 亚洲精品国久久99热| 精品一区二区三区免费播放| 欧美伊人久久久久久久久影院| 久久在线免费观看| 免费观看在线综合| 欧美日韩国产成人在线免费| 亚洲欧洲成人精品av97| 国产麻豆9l精品三级站| 欧美一级片在线看| 香蕉成人伊视频在线观看| 91无套直看片红桃| 日韩电影一区二区三区四区| 99视频精品在线| 国产免费观看久久| 国产最新精品精品你懂的| 欧美一区二区三区在线看| 亚洲午夜三级在线| 在线国产电影不卡| 亚洲情趣在线观看| 波多野结衣亚洲一区| 国产精品视频免费看| 福利视频网站一区二区三区| 精品国产百合女同互慰| 久久99精品国产91久久来源| 日韩一本二本av| 麻豆成人av在线| 欧美岛国在线观看| 久久精品国产亚洲aⅴ| 日韩欧美一区二区不卡| 日本美女视频一区二区| 91精品视频网| 精品在线一区二区| 精品国产不卡一区二区三区| 国产精品一色哟哟哟| 久久久久久影视| 亚洲在线视频免费观看| 欧美三区在线视频| 午夜视频一区二区| 制服.丝袜.亚洲.另类.中文| 日韩精品一区二区在线观看| 亚洲精选一二三| 97aⅴ精品视频一二三区| 亚洲女同ⅹxx女同tv| 91黄色免费观看| 丝袜美腿亚洲一区| 日韩精品一区二区三区四区视频| 久久成人av少妇免费| 久久蜜桃av一区二区天堂 | 欧美精品粉嫩高潮一区二区| 视频精品一区二区| 欧美α欧美αv大片| 国产+成+人+亚洲欧洲自线| 亚洲乱码中文字幕| 欧美精品乱码久久久久久| 精品一区二区三区蜜桃| 中文字幕一区二区5566日韩| 欧美午夜精品电影| 国产一区不卡在线| 亚洲欧美日韩系列|