0

ファイル/proc/net/tcp6の内容を読んでいます

そして、そのip6の表記を「0::1」のように変換しようとしています

以前は ipv4 y で次の方法を使用していました。

struct sockaddr_in tmp_ip;
char ip_str[30];
char ipex[]='00000AF0'; /*read from the file /proc/net/tcp */
tmp_ip.sin_addr.s_addr=(int)strtoll(ipex,NULL,16);
inet_ntop(AF_INET,&tmp_ip.sin_addr,ip_str,60);
printf("ip=%s \n",ip_str);

しかし、ipv6 では /proc/net/tcp6 の内容が大きくなり (33 16 進文字)、おそらく sockaddr_in6 を使用する必要がありますが、変数 sin6_addr.s6_addr は配列であり、単一のログ符号なし int (sin_addr.s_addr など) ではありません。

だから履歴書に。私はこれを通過しようとしています

0000000000000000FFFF00001F00C80A

のようなものに

::ffff:10.200.0.31

編集..

うーん、ex を 16 桁の ex に分解し、sin6_addr.s_addr の配列にフィードすると、おそらくそうなるでしょう。1F00C80A = 10.200.0.31 (ntop 関数を通過)

4

2 に答える 2

1

文字列を配列sscanf()の要素に直接変換するために使用できます。s6_addr

struct in6_addr tmp_ip;
char ip_str[128];
char ipex[]="0000000000000000FFFF00001F00C80A";

if (sscanf(ipex,
    "%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx",
    &tmp_ip.s6_addr[3], &tmp_ip.s6_addr[2], &tmp_ip.s6_addr[1], &tmp_ip.s6_addr[0],
    &tmp_ip.s6_addr[7], &tmp_ip.s6_addr[6], &tmp_ip.s6_addr[5], &tmp_ip.s6_addr[4],
    &tmp_ip.s6_addr[11], &tmp_ip.s6_addr[10], &tmp_ip.s6_addr[9], &tmp_ip.s6_addr[8],
    &tmp_ip.s6_addr[15], &tmp_ip.s6_addr[14], &tmp_ip.s6_addr[13], &tmp_ip.s6_addr[12]) == 16)
{
    inet_ntop(AF_INET6, &tmp_ip, ip_str, sizeof ip_str);
    printf("ip=%s \n",ip_str);
}
于 2010-09-02T01:30:22.483 に答える
0

ありがとう。私はこれをやめました。

cont_ip6=0; 
        cont=0;
        for(i=0;i<34;i++) {
                if (cont ==2) {
                        cont=0;
                        hex_section[2]='\0';
                                tmp_ip6.sin6_addr.s6_addr[cont_ip6]=strtol(hex_section,NULL,16);

                        cont_ip6++;
                }

                hex_section[cont]=ipex[i];
                cont++;

        }

次にinet_ntop

それを私が直した。

16 進数のすべてのペアを反転する必要があります。

::FFFF:10.200.0.31 はこんな配列で終わっていました。

(最後の要素)

FF     |FF    |   00   | 00  :  0A | C8   |   00 | 1F
255    |255   |   0    | 0   :  10 | 200  |   0  | 31

^       ^         ^      ^   :  ^     ^       ^     ^
|       |         |      |      |     |       |     |
|        ---------       |      |      -------      |
 ------------------------        -------------------

したがって、これらを交換する必要があります(各セットの数字で)

だから私はこれをします

tmptmp=0;
for (i=0;i<5;i++){
    tmptmp=tmp_ip6.sin6_addr.s6_addr[i*4+3];
    tmp_ip6.sin6_addr.s6_addr[i*4+3]=tmp_ip6.sin6_addr.s6_addr[i*4];
    tmp_ip6.sin6_addr.s6_addr[i*4]=tmptmp;

    tmptmp=tmp_ip6.sin6_addr.s6_addr[i*4+2];
    tmp_ip6.sin6_addr.s6_addr[i*4+2]=tmp_ip6.sin6_addr.s6_addr[i*4+1];
    tmp_ip6.sin6_addr.s6_addr[i*4+1]=tmptmp;
 }

これによりセットが交換され、 inet_ntop を実行すると ::FFFF:10.200.0.31 と表示されます

(私は一日中これを探していました D:、頭が痛いです) (下手な英語でごめんなさい)

于 2010-09-02T02:25:12.377 に答える