This function or variable may be unsafe - C (СИ)

Узнай цену своей работы

Формулировка задачи:

Всем привет! проблема такая, клиент-серверное приложение было изначально написано под unix. я решил переделать его под windows! приложение реализовано на winsock. соответственно поменял заголовочные файлы, переписал функции! из 15 ошибок, которые выдавал компилятор остались 1 предупреждение и одна ошибка следующего содержания: 1) warning C4996: 'strerror': This function or variable may be unsafe. Consider using strerror_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. 2) error C2664: 'recv' : cannot convert parameter 2 from 'char (*)[21]' to 'char *' Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast вот код программы:
#include <winsock.h>
#pragma comment (linker,"WSock32.Lib",lib)
 
extern errno;     //глобальная переменная, которая хранит код последней ошибки
 
//проверка, задан ли шаблон INADDR_NONE, который обозначает сразу все доступные сетевые интерфейсы
//на некоторых платформах, он может быть не задан.
#ifndef INADDR_NONE
#define INADDR_NONE 0xfffffffff
#endif
 
//функция создания и связывания сокета. объявление
//аргументы:
//port - порт, с которым связывается сервер
//transport - протокол, по которому будет работать сервер (tcp или udp)
//qlen - длина  очереди
int sock(const char *port, const char *transport, int qlen);
 
//главная функция
int main()
{
    int msock, csock;                //дескрипторы сокетов
    struct sockaddr_in  remaddr;            //структура IP-адреса клиента
    unsigned int remaddrs = sizeof(remaddr);    //размер структуры адреса
    char msg[21];                    //буфер сообщения
    
    msock = sock("1231", "tcp", 5);    //создаем tcp сокет и привязываем его к порту 3123, задав очередь 5
    if(msock < 0)            //проверяем значение дескриптора сокета
        return -1;        //завершаем программу
 
    while(1)    //бесконечный цикл
    {
        csock = accept(msock, (struct sockaddr*) &remaddr, &remaddrs);    //принимаем входящее подключение, адрес клиента в remaddr
        if(csock < 0)        //проверяем результат
            printf("Ошибка принятия подключения: %s\n", strerror(errno)); //сообщение об ошибке
        else            //если все нормально - начинаем обмен данными с клиентом
            {
                if(read(csock, &msg, sizeof(msg)) >0 )        //пробуем читать данные от клиента
                {
                    if(strstr(msg, "hello"))            //если получено "hello"
                    {
                        memset(&msg, 0, sizeof(msg));            //обнуляем буфер
                        strcpy(msg, "hello, ");                //формируем строку ответа
                        strcat(msg, inet_ntoa(remaddr.sin_addr));    //преобразовываем адрес клиента в строку
                        strcat(msg, " !!!\n\0");            //завершаем строку ответа
                        write(csock, msg, sizeof(msg));            //отсылаем ответ
                    }
                }
                close(csock);        //закрываем сокет клиента
            }
    }    
    close(msock);        //закрываем сокет сервера
    return 0;
}
//функция создания и связывания сокета. реализация
int sock(const char *port, const char *transport, int qlen)
{
    struct protoent *ppe;        
    struct sockaddr_in sin;
    int s, type;
    //обнуляем структуру адреса
    memset(&sin, 0, sizeof(sin));
    //указываем тип адреса - IPv4, для IPv6 необходимо указать AF_INET6
    sin.sin_family = AF_INET;
    //указываем, в качестве адреса, шаблон INADDR_ANY - все сетевые интерфейсы
    sin.sin_addr.s_addr = INADDR_ANY;
    //задаем порт
    sin.sin_port = htons((unsigned short)atoi(port));
    //преобразовываем имя транспортного протокола в номер протокола
    if((ppe = getprotobyname(transport)) == 0)
        {
            printf("Ошибка преобразования имени транспортного протокола: %s\n", strerror(errno));    //в случае неудачи выводим сообщение ошибки
            return -1;        
        }
    //используем имя протокола для определения типа сокета     
    if(strcmp(transport, "udp") == 0)
        type = SOCK_DGRAM;
    else
        type = SOCK_STREAM;    
    //создаем сокет
    s = socket(PF_INET, type, ppe->p_proto);
    if(s < 0)
        {
            printf("Ошибка создания сокета: %s\n", strerror(errno));    //в случае неудачи выводим сообщение ошибки
            return -1;
        }
    //привязка сокета с проверкой результата
    if(bind(s, (struct sockaddr *)&sin, sizeof(sin)) < 0)
        {
            printf("Ошибка связывания сокета: %s\n", strerror(errno));    //в случае неудачи выводим сообщение ошибки
            return -1;
        }
    //запуск прослушивания с проверкой результата
    if(type == SOCK_STREAM && listen(s, qlen) <0)
        {
            printf("Ошибка прослушивания сокета: %s\n", strerror(errno));    //в случае неудачи выводим сообщение ошибки
            return -1;
        }
    return s;    //возвращаем дескриптор сокета
}

Решение задачи: «This function or variable may be unsafe»

textual
Листинг программы
int WINAPI WinMain(      
    HINSTANCE hInstance,
    HINSTANCE hPrevInstance,
    LPSTR lpCmdLine,
    int nCmdShow
);

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

12   голосов , оценка 3.75 из 5