Рекомендованные сообщения



13 posts in this topic

Начал делать но не работает. В чем проблема?

CMD:givedonate(playerid, params[])
{
	if(sscanf(params,"ud[100]", params[0],params[1])) return SendClientMessage(playerid,COLOR_WARNING,"Используйте /givedonate [id] [кол-во]");
    if(!IsPlayerConnected(params[0]))return  SendClientMessage(playerid,COLOR_WARNING,"Данного ID нет на сервере!");
	if(PLAYER_DATA[params[0]][data_LOGGED] == false)return  SendClientMessage(playerid,COLOR_WARNING,"Данный игрок не прошел авторизацию!");
	if(params[1] < 1 || params[1] > 90000) return SendClientMessage(playerid,COLOR_WARNING,"Нельзя меньше 1 дня и больше 90 дней!");
	new query[256];
    mysql_format(dbHandle,query, sizeof(query), "SELECT * FROM `accounts` WHERE `donate` = '%d'",params[0]);
 	mysql_function_query(dbHandle, query, true, "", "");
 	return true;
}

Прошу объяснить подробно

Edited by Remmi_Feed

Share this post


Link to post
Share on other sites

@Remmi_Feed не работает потому что выполняется запроc SELECT, а должен запрос UPDATE. Почитать можете  в интернете гайды по составлению запросов. Ну вот вам готовый пример: 
 

mysql_format(dbHandle,query, sizeof(query), "UPDATE `accounts` SET `donate` = '%d' WHERE `name` = '%s'",params[0], PLAYER_DATA[playerid][data_NAME]);
mysql_function_query(dbHandle, query, true, "", "");

 

Share this post


Link to post
Share on other sites

@DEST все же не работает команда

Share this post


Link to post
Share on other sites

@Remmi_Feed там не params[0], а params[1] в запросе поменяй. И в третьей строки команды у d 100 убери. К числовому аргументу размер не ставится. 

Share this post


Link to post
Share on other sites

@DEST команда заработала однако вот что в логах появилось

[19:04:48] sscanf warning: Format specifier does not match parameter count.
[19:04:57] sscanf warning: Format specifier does not match parameter count.

 

мне кажется это из за params[2]

Share this post


Link to post
Share on other sites

@Remmi_Feed значит ты не выполнил мои рекомендации из второго поста, или где-то такое же есть нарушение как тут

21 час назад, Remmi_Feed сказал:

d[100]

 

Share this post


Link to post
Share on other sites

Убрал params[2] и появилось вот что

[19:06:55] Warning: PlayerDialogResponse PlayerId: 0 dialog ID doesn't match last sent dialog ID

 

@DEST я думал убрать только [100]

Share this post


Link to post
Share on other sites

@Remmi_Feed это с этой системой абсолютно никак не связано. Только 100 из команды и нужно было убрать. 

Share this post


Link to post
Share on other sites

@DEST работает только на мне :) На остальных никакого эффекта 

Share this post


Link to post
Share on other sites
23 часа назад, DEST сказал:

mysql_format(dbHandle,query, sizeof(query), "UPDATE `accounts` SET `donate` = '%d' WHERE `name` = '%s'",params[0], PLAYER_DATA[playerid][data_NAME]); mysql_function_query(dbHandle, query, true, "", "");

здесь вместо playerid нужно подставить аргумент игрока, т.е. params[0]. 

Share this post


Link to post
Share on other sites

@DEST то есть получится?

mysql_format(dbHandle,query, sizeof(query), "UPDATE `accounts` SET `donate` = '%d' WHERE `name` = '%s'",params[0], PLAYER_DATA,params[2]); mysql_function_query(dbHandle, query, true, "", "");

 

Share this post


Link to post
Share on other sites

@Remmi_Feed а теперь перечитай мой пост и сделай как положено. Что заменить я выделил, на что написал.

Share this post


Link to post
Share on other sites

@DEST дошло)

Edited by Remmi_Feed

Share this post


Link to post
Share on other sites
Guest
This topic is now closed to further replies.
Sign in to follow this  
Followers 0

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • odosenok
      By odosenok
      Уже давно на просторах интернета летает эксплоит от SA:MP 0.3e. Он позволял выполнить любой код на ассемблере на удаленной машине (сторона игрока, клиент). Однако, выполнять можно было этот код с некоторыми оговорками: 
      В коде надо было избегать нулей (так как экплоит был строкой для TD) В конце исполнения кода возвращения из стека не происходило (игра завершалась ошибкой).  
      Поскольку CR основана на версии 0.3e, эксплоит работает и на ней. Игра в этом варианте немного защищена adapt.dll (закрыта возможность хуков) и изменен gta_sa.exe (в код внесены 1024 байта неизвестной природы). Я был очень удивлен, что за все время существования такой дыры, ее никто толком не использовал
       
      Эксплоит в моем исполнении немного доведен до ума. Что есть на данный момент? Эксплоит, выполнясь на стороне клиента, выполняет следующие действия:
      Открывает потоковый сокет, скачивает с сервера .dll, загружает ее в память игры Если в процессе этого происходит какая либо ошибка игра закрывается Если все прошло успешно, игра продолжает работать, а выполненый код (сам эксплоит) выгружается  
      Что сейчас умеет загружаемая .dll?
      Взятие аппаратных ключей через утилиту "wmic". Полный доступ к адресному пространству процесса (можно модифицировать игру изнутри). Доступ к машине на уровне прав выполнения игры (скачивание/загрузка файлов)  
      Так как все три выше изложенных пункта включают в себя доступ к компьютеру, перед каким либо вмешательством поступает запрос на одобрение действий. В моем варианте запрашивается доступ к процессу и к папке с игрой
      Что уже есть на базе этого всего? 
      Контроль и модификация пакетов RakNet в обе стороны. Возможность общаться между клиентом и сервером текстом в моде на сервере, например, PluginSend(playerid, "$set_gravity 0.6"), или что-то такое. Главное - понимание, что функция выполнения этой строки будет заложена в .dll. В данный момент через $fullinfo можно получить данные о процессоре, видеокарте, материнской плате, всех носителях и другом установленном оборудовании. Система аккаунтов, наказаний и персонажей. При заходе игрока сервер уже знает, кто присоединился, и, однозначно идентифицируя игрока, проверяет его наказания, выдает ему список персонажей (пресетов скин, цвет, ник, статистика) для игры. Конфигуратор оружейных настроек. Позволяет менять дамаг, точность, магазин, анимации, разброс, скорость стрельбы, ношение одного или двух орудий. Конфигуратор палитры цветов транспорта. Позволяет манипулировать всеми слотами цветов транспорта, делать переливающиеся или мигающие цвета (в реальном времени) по RGB.  
      Таким образом данный эксплоит представляет собой плагин, способный манипулировать клиентом, причем делается это не через средства самого сервера и Pawn, а напрямую на целевой машине. По сему здесь важно понимать, что уязвимость, позволяющая работать с клиентом напрямую, является очень перспективной.
       
      Все вышеизложенное дает мне надежду на то что, что с игрой GTA Criminal Russia не все кончено, и силами разработчиков можно привнести в нее новых красок, по сему я бы хотел пообщаться с вами и по возможности создать сервер для совместных поделок на базе CR. Так как сама игра в ее текущем варианте умирает, ей нужен либо новый виток развития, либо забвение (чего я не особо хочу).
       
      Всех заинтересовавшихся прошу в личные сообщения @Iku Seiko, telegram @romuwka или discord ikuseiko#0491.
    • sweet
      By sweet
      Хелп,при компиле выдает ошибку C:\Users\PC\Desktop\pawno\pawno\include\objects.inc(1104) : error 029: invalid expression, assumed zero
      Сама строка в которой ошибка:    {-2032.7073,-73.8643,35.2484, -2006.3911,-52.6238,35.2704},
      Закройте тему,проблема решилась сама по себе