ANTICHAT.XYZ    VIDEO.ANTICHAT.XYZ    НОВЫЕ СООБЩЕНИЯ    ФОРУМ  
Баннер 1   Баннер 2

ANTICHAT — форум по информационной безопасности, OSINT и технологиям

ANTICHAT — русскоязычное сообщество по безопасности, OSINT и программированию. Форум ранее работал на доменах antichat.ru, antichat.com и antichat.club, и теперь снова доступен на новом адресе — forum.antichat.xyz.
Форум восстановлен и продолжает развитие: доступны архивные темы, добавляются новые обсуждения и материалы.
⚠️ Старые аккаунты восстановить невозможно — необходимо зарегистрироваться заново.
Вернуться   Форум АНТИЧАТ > Программирование > С/С++, C#, Delphi, .NET, Asm
   
Ответ
 
Опции темы Поиск в этой теме Опции просмотра

переделать под windows
  #1  
Старый 17.02.2010, 18:04
al072
Новичок
Регистрация: 25.05.2008
Сообщений: 20
Провел на форуме:
44941

Репутация: 0
По умолчанию переделать под windows

Всем привет! проблема такая, клиент-серверное приложение было изначально написано под 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

вот код программы (пишу в VS2008 на С++):

Код:
#define _CRT_SECURE_NO_WARNINGS 1 
#include <winsock.h>
#pragma comment (lib,"WSock32.Lib")
#include <iostream>

//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(recv(csock, msg, sizeof(msg),0) >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");            //завершаем строку ответа
                        send(csock, msg, sizeof(msg),0);            //отсылаем ответ
                    }
                }
                closesocket(csock);        //закрываем сокет клиента
            }
    }    
    closesocket(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;    //возвращаем дескриптор сокета
}

Последний раз редактировалось al072; 02.03.2010 в 14:43..
 
Ответить с цитированием

  #2  
Старый 17.02.2010, 18:23
hs_alex
Новичок
Регистрация: 13.07.2007
Сообщений: 8
Провел на форуме:
225643

Репутация: 3
По умолчанию

1) warning C4996: 'strerror': This function or variable may be unsafe. Consider using strerror_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.

Тебе предлагается использовать strerror_s вместо strerror.

2) error C2664: 'recv' : cannot convert parameter 2 from 'char (*)[21]' to 'char *'

В параметрах recv, перед второй переменной напиши (CHAR *), чтобы привести твою переменную типа char[21] к типу, который требуется в функции.

Ошибки выдаются для кода, который отсутствует в посте.

Good Luck!
 
Ответить с цитированием

  #3  
Старый 17.02.2010, 20:15
al072
Новичок
Регистрация: 25.05.2008
Сообщений: 20
Провел на форуме:
44941

Репутация: 0
По умолчанию

Цитата:
Сообщение от hs_alex  
1) warning C4996: 'strerror': This function or variable may be unsafe. Consider using strerror_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.

Тебе предлагается использовать strerror_s вместо strerror.

2) error C2664: 'recv' : cannot convert parameter 2 from 'char (*)[21]' to 'char *'

В параметрах recv, перед второй переменной напиши (CHAR *), чтобы привести твою переменную типа char[21] к типу, который требуется в функции.

Ошибки выдаются для кода, который отсутствует в посте.

Good Luck!
код на который ругается компилятор присутствует в посте, вот фрагмент:
Код:
if(recv(csock,&msg, sizeof(msg),0) >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");			//завершаем строку ответа
						send(csock, msg, sizeof(msg),0);			//отсылаем ответ
					}
				}
попробовал привести к типу (char*), таким образом, которым вы посоветовали, компилятор выдал 8 предупреждений и 2 ошибки:

error LNK2019: unresolved external symbol _WinMain@16 referenced in function ___tmainCRTStartup

fatal error LNK1120: 1 unresolved externals

warning C4996: 'strerror': This function or variable may be unsafe. Consider using strerror_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.

warning C4996: 'strcpy': This function or variable may be unsafe. Consider using strcpy_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.

warning C4996: 'strcat': This function or variable may be unsafe. Consider using strcat_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.

warning C4996: 'strcat': This function or variable may be unsafe. Consider using strcat_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.

warning C4996: 'strerror': This function or variable may be unsafe. Consider using strerror_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS.
 
Ответить с цитированием

  #4  
Старый 18.02.2010, 14:55
arpm
Новичок
Регистрация: 06.04.2008
Сообщений: 8
Провел на форуме:
21887

Репутация: 10
По умолчанию

http://forum.antichat.ru/showthread.php?p=674960#post674960
 
Ответить с цитированием

  #5  
Старый 19.02.2010, 14:41
hs_alex
Новичок
Регистрация: 13.07.2007
Сообщений: 8
Провел на форуме:
225643

Репутация: 3
По умолчанию

Откорректировал:
1. #pragma comment(lib, "WSock32.Lib")
2. if(recv(csock, msg, sizeof(msg),0) >0 )

Откомпилировал у себя в 2008 Express Edition - все ОК.

Пробуй.
 
Ответить с цитированием

  #6  
Старый 19.02.2010, 15:02
sn0w
Статус пользователя:
Регистрация: 26.07.2005
Сообщений: 568
Провел на форуме:
1290766

Репутация: 1236


По умолчанию

strcat и тд меняй на lstrcat и тд если не хочешь рантайм использовать, также ignore all default libraries, "ENTRY:WinMain" и поскакали и поскакали)
__________________


snow white world wide
 
Ответить с цитированием

  #7  
Старый 19.02.2010, 15:18
sn0w
Статус пользователя:
Регистрация: 26.07.2005
Сообщений: 568
Провел на форуме:
1290766

Репутация: 1236


По умолчанию

вот так без црт но придется ручками дописывать

Код:
#include <winsock2.h>
#pragma optimize("gsy", on) 
#pragma comment(linker, "/ENTRY:WinMain")

// добавь в проекте либы: ntdll.lib ws2_32.lib

int errn;     //глобальная переменная, которая хранит код последней ошибки

//функция создания и связывания сокета. объявление
//аргументы:
//port - порт, с которым связывается сервер
//transport - протокол, по которому будет работать сервер (tcp или udp)
//qlen - длина  очереди
int sock(const char *port, const char *transport, int qlen);

HANDLE ghStdOut;

//////////////////////////////////////////////////////////////////////////
char *cstrerror(int code)
{
	static char errbuf[512];

	// ... parse error

	return errbuf;
}

//////////////////////////////////////////////////////////////////////////
VOID cprintf(LPCSTR fmt...)
{
	DWORD dwCount;

	va_list vl;
	char msg[1024];

	va_start(vl,fmt);
	wvsprintf(msg,fmt,vl);
	va_end(vl);

	WriteConsole( ghStdOut, msg, lstrlen(msg), &dwCount, NULL);
}


//////////////////////////////////////////////////////////////////////////
//главная функция
int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
{
	int msock, csock;                //дескрипторы сокетов
	struct sockaddr_in  remaddr;            //структура IP-адреса клиента
	unsigned int remaddrs = sizeof(remaddr);    //размер структуры адреса
	char msg[21];                    //буфер сообщения

	WSADATA wsd; // init winsock
	WSAStartup(0x202, &wsd);

	// get console
	AllocConsole();
	ghStdOut = GetStdHandle(STD_OUTPUT_HANDLE);
	SetConsoleTextAttribute(ghStdOut, FOREGROUND_GREEN | FOREGROUND_INTENSITY);

	msock = sock("1231", "tcp", 5);    //создаем tcp сокет и привязываем его к порту 3123, задав очередь 5
	if(msock < 0)            //проверяем значение дескриптора сокета
		return -1;        //завершаем программу

	while(1)    //бесконечный цикл
	{
		csock = accept(msock, (struct sockaddr*) &remaddr, (int*)&remaddrs);    //принимаем входящее подключение, адрес клиента в remaddr
		if(csock < 0)        //проверяем результат
			cprintf("Ошибка принятия подключения: %s\n", cstrerror(errn)); //сообщение об ошибке
		else            //если все нормально - начинаем обмен данными с клиентом
		{
			if(recv(csock, &msg[0], sizeof(msg),0) >0 )        //пробуем читать данные от клиента
			{
			//	if(strstr(msg, "hello"))            //если получено "hello"
				if(!lstrcmp(msg,"hello"))
				{
					memset(&msg, 0, sizeof(msg));            //обнуляем буфер
					lstrcpy(msg, "hello, ");                //формируем строку ответа
					lstrcat(msg, inet_ntoa(remaddr.sin_addr));    //преобразовываем адрес клиента в строку
					lstrcat(msg, " !!!\n\0");            //завершаем строку ответа
					send(csock, msg, sizeof(msg),0);            //отсылаем ответ
				}
			}
			closesocket(csock);        //закрываем сокет клиента
		}
	}    
	closesocket(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)); // @ntdll.dll
	//указываем тип адреса - 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)
	{
		cprintf("Ошибка преобразования имени транспортного протокола: %s\n", cstrerror(errn));    //в случае неудачи выводим сообщение ошибки
		return -1;        
	}
	//используем имя протокола для определения типа сокета     
	if(lstrcmp(transport, "udp") == 0)
		type = SOCK_DGRAM;
	else
		type = SOCK_STREAM;    
	//создаем сокет
	s = socket(PF_INET, type, ppe->p_proto);
	if(s < 0)
	{
		cprintf("Ошибка создания сокета: %s\n", cstrerror(errn));    //в случае неудачи выводим сообщение ошибки
		return -1;
	}
	//привязка сокета с проверкой результата
	if(bind(s, (struct sockaddr *)&sin, sizeof(sin)) < 0)
	{
		cprintf("Ошибка связывания сокета: %s\n", cstrerror(errn));    //в случае неудачи выводим сообщение ошибки
		return -1;
	}
	//запуск прослушивания с проверкой результата
	if(type == SOCK_STREAM && listen(s, qlen) <0)
	{
		cprintf("Ошибка прослушивания сокета: %s\n", cstrerror(errn));    //в случае неудачи выводим сообщение ошибки
		return -1;
	}
	return s;    //возвращаем дескриптор сокета
}
по поводу комментов, на будущее, не стоит писать например так:
Код:
i+=2; // тут увеличиваем счетчик на 2 единицы
__________________


snow white world wide

Последний раз редактировалось sn0w; 19.02.2010 в 15:22..
 
Ответить с цитированием

  #8  
Старый 02.03.2010, 14:49
al072
Новичок
Регистрация: 25.05.2008
Сообщений: 20
Провел на форуме:
44941

Репутация: 0
По умолчанию

Цитата:
Сообщение от hs_alex  
Откорректировал:
1. #pragma comment(lib, "WSock32.Lib")
2. if(recv(csock, msg, sizeof(msg),0) >0 )

Откомпилировал у себя в 2008 Express Edition - все ОК.

Пробуй.
Подправил код, подправил заголовочные файлы!(в посте тоже код обновил) всеравно выдает две ошибки, не пойму почему не компилиться:

LNK2019: unresolved external symbol _WinMain@16 referenced in function ___tmainCRTStartup

LNK1120: 1 unresolved externals

Еще вызывает подозрение вот эта строчка кода : extern errno;

она в самом начале почти! я ее закоментил, если откоментировать вылазят совсем другие ошибки! Если ты добился того, что все компилиться без проблем, и если не трудно может посмотришь еще раз на код в посте, что-то наверняка я упускаю, но не пойму где?
 
Ответить с цитированием
Ответ



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
FAQ по Windows 7 -Gory King- Windows 35 08.06.2010 17:22
Оптимизация Windows Vista _-Ramos-_ Windows 25 25.08.2009 19:25



Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
 


Быстрый переход




ANTICHAT.XYZ