为什么我会收到一条警告说“赋值从整数中生成没有强制转换的指针”?

时间:2013-11-08 05:19:57

标签: c sockets gcc-warning

这是我在混杂模式下从以太网接收原始数据包的代码。编译时我在代码行中收到警告

logfile=open("sniff_data.bin",O_CREAT|O_APPEND|O_TRUNC,0777);

警告:赋值使用整数而不使用强制转换[默认情况下启用]。我在谷歌检查但无法找到解决方案。 谁能告诉我解决方案,哪里出错了?

void ProcessPacket(unsigned char* , int);
void print_ip_header(unsigned char* , int);
void print_tcp_packet(unsigned char * , int );
void print_udp_packet(unsigned char * , int );
void print_icmp_packet(unsigned char* , int );
void PrintData (unsigned char* , int);

FILE *logfile;
struct sockaddr_in source,dest;
int i,j;

int main()
{
    int saddr_size,data_size;
    struct sockaddr saddr;
    gopromiscous();
    unsigned char *buffer = (unsigned char *) malloc(1024);  

    logfile=open("sniff_data.bin",O_CREAT|O_APPEND|O_TRUNC,0777);  

    if(logfile==NULL)
    {
        printf("Unable to create sniff_data file.");
    }
    printf("\n Starting..\n");

    int sock_raw = socket( AF_PACKET , SOCK_RAW , htons(ETH_P_ALL)) ;
    setsockopt(sock_raw , SOL_SOCKET , SO_BINDTODEVICE , "eth0" , strlen("eth0")+ 1 );

    if(sock_raw < 0)
    {

        perror("Socket Error");
        return 1;
    }
    int count=30; 
    while(count>=0)
    { 
        count--;
        saddr_size = sizeof saddr;
        //Receive a packet
        data_size = recvfrom(sock_raw , buffer , 1024, 0 , &saddr , 
          (socklen_t*)&saddr_size);
        if(data_size <0 )
        {
            printf("Recvfrom error , failed to get packets\n");
            return 1;
        }

        fwrite(buffer, data_size, 1, logfile);    

    }

    fclose(logfile);
    close(sock_raw);
    printf("\n");
    printf(" Finished\n\n");
    return 0;
}


int gopromiscous()
  {

    int fd;
    struct ifreq eth;

    fd = socket(AF_INET, SOCK_PACKET, htons(0x800));

    strcpy(eth.ifr_name, "eth0");

    ioctl(fd, SIOCGIFFLAGS, &eth);

    eth.ifr_flags |= IFF_PROMISC;

    ioctl(fd, SIOCSIFFLAGS, &eth);

    printf("\n Entered Promiscuous Mode Successfully\n");

 }

3 个答案:

答案 0 :(得分:6)

从男人2开始

    int open(const char *path, int oflag, ...);

打开返回一个int(文件描述符),而不是一个FILE *。 因此警告以及您的代码无法工作的原因。

您可能希望将FILE *更改为int,并使用write(2)和close(2)代替fwrite和flcose

或者使用fopen(3)

答案 1 :(得分:2)

或使用fopen()返回FILE *

答案 2 :(得分:0)

open()函数调用返回file descriptor类型的int。但是您要将file stream的开放返回值指定为FILE *类型。

当您使用open()时,您应该将close()与特定描述符fclose()

一起使用