Вопросы

Решил сделать команду чисто для теста, отвечает она за регистрацию PIN-кода у админа, вроде все шло четко, но он не хочет сохранятся в базу данных

 

Спойлер

case DLG_REGADMIN:
		{
			if(response)
			{
				if(!strlen(inputtext))
				{
					ShowAdminReg(playerid);
					return SCM(playerid, COLOR_RED, !"[Ошибка] {FFFFFF}Придумайте PIN-код");
				}
				if(strval(inputtext) < 1000 || strval(inputtext) > 9999)
				{
					ShowAdminReg(playerid);
					return SCM(playerid, COLOR_RED, !"[Ошибка] {FFFFFF}PIN-код должен состоять из 4 цифр!");
				}
				else
				{
					strmid(player_info[playerid][ADMINPASS], inputtext, 0, strlen(inputtext), 5);
					SCM(playerid, COLOR_WHITE, "Вы успешно зарегистрировали админ аккаунт");
				}
			}
			else
			{
				SPD(playerid, -1, 0, " ", " ", " ", "");
			}
		}
Спойлер


static const fnt_query[] = "INSERT INTO `users` (`adminpassword`) VALUES ('%s')";
new query[sizeof(fnt_query)+(-2+4)];
format(query, sizeof(query), fnt_query, player_info[playerid][ADMINPASS]);
mysql_query(dbHandle, query);

 

 

 

Screenshot_43.png

Screenshot_42.png

Отредактировано пользователем Умелец

Поделиться сообщением


Ссылка на сообщение

13 ответов на этот вопрос

  • 0
2 часа назад, Умелец сказал:

new sql_query[128];
      format(sql_query, sizeof(sql_query), "UPDATE `users` SET `adminpassword` = '%d' WHERE `id` = '%d'", player_info[playerid][ADMINPASS], player_info[playerid][ID]);
      mysql_query(dbHandle, sql_query);
      strmid(player_info[playerid][ADMINPASS], inputtext, 0, strval(inputtext));

 

Вы в базу данных загружаете старое значение переменной и лишь затем обновляете содержимое переменной. И вообще это странно, что компилятор позволил использовать функцию strmid для переменной player_info[playerid][ADMINPASS].

 

Спойлер

case DLG_REGADMIN:
{
	if(response)
	{
		if(!strlen(inputtext))
		{
			ShowAdminReg(playerid);
			return SCM(playerid, COLOR_RED, !"[Ошибка] {FFFFFF}Придумайте PIN-код");
		}
		
		new value = strval(inputtext);
		
		if(value < 1000 || value > 9999)
		{
			ShowAdminReg(playerid);
			return SCM(playerid, COLOR_RED, !"[Ошибка] {FFFFFF}PIN-код должен состоять из 4 цифр!");
		}
		
		player_info[playerid][ADMINPASS] = value;
			
		new sql_query[128];
		format(sql_query, sizeof(sql_query), "UPDATE `users` SET `adminpassword` = '%d' WHERE `id` = '%d'", player_info[playerid][ADMINPASS], player_info[playerid][ID]);
		mysql_query(dbHandle, sql_query);
		
		SCM(playerid, COLOR_WHITE, "Вы успешно зарегистрировали админ аккаунт");
	}
	else
	{
		SPD(playerid, -1, 0, " ", " ", " ", "");
	}
}

 

 

Поделиться сообщением


Ссылка на сообщение
  • 0

Если это PIN-Code, зачем хранить его как строку?
Создай переменную целочисленного значения, и записывать легче, и хранить, и извлекать.

Поделиться сообщением


Ссылка на сообщение
  • 0

@20th century спасибо, попробую

Поделиться сообщением


Ссылка на сообщение
  • 0

@20th century Ну не знаю, в консоль выводит значение переменной но в базу не записывает, 2002 это PIN-код

Screenshot_44.png

Отредактировано пользователем Умелец

Поделиться сообщением


Ссылка на сообщение
  • 0

@Умелец 



new sql_query[128];
format(sql_query, sizeof(sql_query), "UPDATE `users` SET `adminpassword` = '%d' WHERE `id` = '%d'", player_info[playerid][ADMINPASS], player_info[playerid][ID]/*(ID на своё)*/);
mysql_query(dbHandle, query);

попробуйте

 

Поделиться сообщением


Ссылка на сообщение
  • 0

@keyl1337 Теперь записывает кривовато

Screenshot_45.png

Screenshot_46.png

Поделиться сообщением


Ссылка на сообщение
  • 0

@Умелец, а покажите-ка объявление переменной, в которой храните PIN.

Поделиться сообщением


Ссылка на сообщение
  • 0

Поделиться сообщением


Ссылка на сообщение
  • 0

Вы забыли поменять VARCHAR на INTEGER в таблице.

Поделиться сообщением


Ссылка на сообщение
  • 0

@20th century Стоит

Screenshot_48.png

Поделиться сообщением


Ссылка на сообщение
  • 0

Ещё раз дай весь код абсолютно, всё что связано с пин-кодом.

Поделиться сообщением


Ссылка на сообщение
  • 0

@20th century 

Спойлер

stock ShowAdminReg(playerid)
{
	new dialog[38+(-2+MAX_PLAYER_NAME)];
	format(dialog, sizeof(dialog),
		"{FFFFFF}Придумайте Пин-Код для админки");
	SPD(playerid, DLG_REGADMIN, DIALOG_STYLE_INPUT, "{F6B352}Sand Role Play", dialog, "Далее", "Выход");
}

 

Спойлер

case DLG_REGADMIN:
{
  if(response)
  {
    if(!strlen(inputtext))
    {
      ShowAdminReg(playerid);
      return SCM(playerid, COLOR_RED, !"[Ошибка] {FFFFFF}Придумайте PIN-код");
    }
    if(strval(inputtext) < 1000 || strval(inputtext) > 9999)
    {
      ShowAdminReg(playerid);
      return SCM(playerid, COLOR_RED, !"[Ошибка] {FFFFFF}PIN-код должен состоять из 4 цифр!");
    }
    else
    {
      new sql_query[128];
      format(sql_query, sizeof(sql_query), "UPDATE `users` SET `adminpassword` = '%d' WHERE `id` = '%d'", player_info[playerid][ADMINPASS], player_info[playerid][ID]);
      mysql_query(dbHandle, sql_query);
      strmid(player_info[playerid][ADMINPASS], inputtext, 0, strval(inputtext));
      printf("%d", player_info[playerid][ADMINPASS]);
      SCM(playerid, COLOR_WHITE, "Вы успешно зарегистрировали админ аккаунт");
    }
  }
  else
  {
    SPD(playerid, -1, 0, " ", " ", " ", "");
  }

}

 

 

Поделиться сообщением


Ссылка на сообщение
  • 0

@odosenok Огромное спасибо, сам не мог понять этого :D

Поделиться сообщением


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };
    • Garnik
      От Garnik
      ERRORS:
      : error 017: undefined symbol "HouseInfo"
      : error 017: undefined symbol "OWNABLEHOUSES"
      : error 029: invalid expression, assumed zero
      : fatal error 107: too many error messages on one line
      ===============================================================================================================
       
       
      ================================================================================================================
      CMD:addhouse(playerid,params[])
      {
              if(PI[playerid][pAdmin] < 10)return false;
              new string[650];
              new house_class, house_price;
              new Float:X, Float:Y, Float:Z, Float:A;
              if(sscanf(params, "ii", house_class,house_price))
              {
                      SendClientMessage(playerid, -1, "???????????: /addhouse [????? ??????] [???? ???????]");
                      SendClientMessage(playerid, -1, "??????: [1 - ??????-?????] [2 - ???????-?????] [3 - ???????-?????] [4 - ???????-?????]");
                      return 1;
              }
              if(house_class > 4 || house_class < 1)
              {
                      SendClientMessage(playerid, -1, "ID ????????? ?? 1 ?? 4");
                      return 1;
              }
              //
              GetPlayerPos(playerid,X,Y,Z);
              GetPlayerFacingAngle(playerid,A);
              HouseInfo[OWNABLEHOUSES][hEnter_X]=X;
              HouseInfo[OWNABLEHOUSES][hEnter_Y]=Y;
              HouseInfo[OWNABLEHOUSES][hEnter_Z]=Z;
              HouseInfo[OWNABLEHOUSES][hEnter_A]=A;
              HouseInfo[OWNABLEHOUSES][hKlass]=house_class;
              HouseInfo[OWNABLEHOUSES][hCost]=house_price;
              string="";
              strmid(HouseInfo[OWNABLEHOUSES][hOwner],"The State",0,strlen("The State"),28);
              format(string, 144, "?? ??????? ??????? ??? ????? {e7e7e7}%d {ffffff}????????? ???????: {e7e7e7}%d",OWNABLEHOUSES+1,HouseInfo[OWNABLEHOUSES][hCost]);
              SendClientMessage(playerid,-1,string);
              //
              string="";
              format(string,1500,"INSERT INTO `houses`(`ID`,`Enter_X`, `Enter_Y`, `Enter_Z`, `Enter_A`,`Exit_X`, `Exit_Y`, `Exit_Z`, `Owner`, `Cost` , `Klass`, `Interior`, `Level`) VALUES ('%d','%.2f','%.2f','%.2f','%.2f','267.1','305','999.148','The State','%d','%d','2','1')",
              OWNABLEHOUSES+1,HouseInfo[OWNABLEHOUSES][hEnter_X],HouseInfo[
              OWNABLEHOUSES][hEnter_Y],HouseInfo[OWNABLEHOUSES][hEnter_Z]
              ,HouseInfo[OWNABLEHOUSES][hEnter_A],HouseInfo[OWNABLEHOUSES]
              [hCost],HouseInfo[OWNABLEHOUSES][hKlass]);
              mysql_tquery(mysql, string);
              OWNABLEHOUSES++;
              return 1;
      }
       0
       Ответить
    • Garnik
      От Garnik
      ERRORS:
      : error 017: undefined symbol "HouseInfo"
      : error 017: undefined symbol "OWNABLEHOUSES"
      : error 029: invalid expression, assumed zero
      : fatal error 107: too many error messages on one line
      ===============================================================================================================
       
       
      ================================================================================================================
      CMD:addhouse(playerid,params[])
      {
              if(PI[playerid][pAdmin] < 10)return false;
              new string[650];
              new house_class, house_price;
              new Float:X, Float:Y, Float:Z, Float:A;
              if(sscanf(params, "ii", house_class,house_price))
              {
                      SendClientMessage(playerid, -1, "???????????: /addhouse [????? ??????] [???? ???????]");
                      SendClientMessage(playerid, -1, "??????: [1 - ??????-?????] [2 - ???????-?????] [3 - ???????-?????] [4 - ???????-?????]");
                      return 1;
              }
              if(house_class > 4 || house_class < 1)
              {
                      SendClientMessage(playerid, -1, "ID ????????? ?? 1 ?? 4");
                      return 1;
              }
              //
              GetPlayerPos(playerid,X,Y,Z);
              GetPlayerFacingAngle(playerid,A);
              HouseInfo[OWNABLEHOUSES][hEnter_X]=X;
              HouseInfo[OWNABLEHOUSES][hEnter_Y]=Y;
              HouseInfo[OWNABLEHOUSES][hEnter_Z]=Z;
              HouseInfo[OWNABLEHOUSES][hEnter_A]=A;
              HouseInfo[OWNABLEHOUSES][hKlass]=house_class;
              HouseInfo[OWNABLEHOUSES][hCost]=house_price;
              string="";
              strmid(HouseInfo[OWNABLEHOUSES][hOwner],"The State",0,strlen("The State"),28);
              format(string, 144, "?? ??????? ??????? ??? ????? {e7e7e7}%d {ffffff}????????? ???????: {e7e7e7}%d",OWNABLEHOUSES+1,HouseInfo[OWNABLEHOUSES][hCost]);
              SendClientMessage(playerid,-1,string);
              //
              string="";
              format(string,1500,"INSERT INTO `houses`(`ID`,`Enter_X`, `Enter_Y`, `Enter_Z`, `Enter_A`,`Exit_X`, `Exit_Y`, `Exit_Z`, `Owner`, `Cost` , `Klass`, `Interior`, `Level`) VALUES ('%d','%.2f','%.2f','%.2f','%.2f','267.1','305','999.148','The State','%d','%d','2','1')",
              OWNABLEHOUSES+1,HouseInfo[OWNABLEHOUSES][hEnter_X],HouseInfo[
              OWNABLEHOUSES][hEnter_Y],HouseInfo[OWNABLEHOUSES][hEnter_Z]
              ,HouseInfo[OWNABLEHOUSES][hEnter_A],HouseInfo[OWNABLEHOUSES]
              [hCost],HouseInfo[OWNABLEHOUSES][hKlass]);
              mysql_tquery(mysql, string);
              OWNABLEHOUSES++;
              return 1;
      }