Вопросы

Помогите у меня регистрация админа повторно идет и в бд не сохраняется 

Цитата

stock ALoginPanel(playerid)
{
    new query_string[42 - 2 + MAX_PLAYER_NAME],
        Cache:mysql_result,
        rows;

    format(query_string, sizeof query_string, "SELECT * FROM "T_ADMIN" WHERE `name` = '%s'", GetName(playerid));
    mysql_result = mysql_query(dbHandle, query_string);

    cache_get_row_count(rows);

    if(!rows) return cache_delete(mysql_result);

    cache_get_value_name_int(0, "registration", admin_info[playerid][admin_apanel_registration]);
    cache_get_value_name(0, "password", admin_info[playerid][admin_password], MAX_ADMIN_PASSWORD); 
    cache_get_value_name_int(0, "level", admin_info[playerid][admin_level]);
    cache_delete(mysql_result);

    if(admin_info[playerid][admin_apanel_registration] == 0)
    {
        Dialog_Open(playerid, Dialog:ADMIN_ALOGIN, DIALOG_STYLE_PASSWORD,
            !""C_WHITE"Регистрация в "C_SERVER"A-PANEL",
            !"\n\
            "C_WHITE"Введите пароль, который в дальнейшем будет использоваться для входа в "C_SERVER"A-PANEL.\n\n\
            "C_SUCCESS"Примечание:\n\
            "C_WHITE"- Пароль должен содержать от 6-и до 16-и символов.\n\
            "C_WHITE"- Пароль должен состоять из латинских символов и цифр (A-Z, a-z, 0-9).",
            !"Принять", !"Отмена"
        );
    }
    else
    {
        Dialog_Open(playerid, Dialog:ADMIN_ALOGIN, DIALOG_STYLE_PASSWORD,
            !""C_WHITE"Авторизация в "C_SERVER"A-PANEL",
            !"\n\
            "C_WHITE"Введите Ваш пароль от панели администрирования.",
            !"Принять", !"Отмена"
        );
    }
    return true;
}

DialogResponse:ADMIN_ALOGIN(playerid, response, listitem, inputtext[]) 
{
    if(!response) return true;

    if(admin_info[playerid][admin_apanel_registration] == 0)
    {
        for(new i = strlen(inputtext)-1; i != -1; i--) 
        {
            switch(inputtext
            {
                case '0'..'9', 'a'..'z', 'A'..'Z': continue; 
                default: return Dialog_Open(playerid, Dialog:DLG_ALOGIN, DIALOG_STYLE_PASSWORD,
                    !""C_WHITE"Регистрация в "C_SERVER"A-PANEL",
                    !"\n\
                    "C_WHITE"Введите пароль, который в дальнейшем будет использоваться для входа в "C_SERVER"A-PANEL.\n\n\
                    "C_SERVER"Примечание:\n\
                    "C_WHITE" - Пароль должен содержать от 6-и до 16-и символов.\n\
                    "C_WHITE" - Пароль должен состоять из латинских символов и цифр (A-Z, a-z, 0-9).",
                    !"Принять", !"Отмена"
                );
            }
        }

        if(strlen(inputtext) < MIN_ADMIN_PASSWORD || strlen(inputtext) > MAX_ADMIN_PASSWORD 
            || strfind(inputtext, "=", true) != -1
        ) return Dialog_Open(playerid, Dialog:DLG_ALOGIN, DIALOG_STYLE_PASSWORD,
            !""C_WHITE"Регистрация в "C_SERVER"A-PANEL",
            !"\n\
            "C_WHITE"Введите пароль, который в дальнейшем будет использоваться для входа в "C_SERVER"A-PANEL.\n\n\
            "C_SERVER"Примечание:\n\
            "C_WHITE" - Пароль должен содержать от 6-и до 16-и символов.\n\
            "C_WHITE" - Пароль должен состоять из латинских символов и цифр (A-Z, a-z, 0-9).",
            !"Принять", !"Отмена"
        );

        RegistrationAdminAccount(playerid, inputtext);
    }
    else
    {
        if(!strlen(inputtext)) return Dialog_Open(
            playerid, Dialog:DLG_ALOGIN, DIALOG_STYLE_PASSWORD,
            !""C_WHITE"Авторизация в "C_SERVER"A-PANEL",
            !"\n\
            "C_WHITE"Введите Ваш пароль от панели администрирования.",
            !"Принять", !"Отмена"
        );

        AuthorizationAdminAccount(playerid, inputtext);
    }
    return true;
}

stock RegistrationAdminAccount(playerid, password[])
{
    new string[72 - 12 + MAX_PLAYER_NAME + 3 + 3 + 16 + 64*2];

    mysql_format(dbHandle, string, sizeof string,
            "UPDATE "T_ADMIN" SET \
                `password` = '%e', `last_connect` = NOW(), `registration` = '1' \
            WHERE `name` = '%s'",
        password, GetName(playerid)
    );
    mysql_tquery(dbHandle, string);

    gAdminLogged[playerid] = true;
    DisableAntiCheatForAdmin(playerid);
    Iter_Add(connected_admins, playerid);

    format(string, sizeof(string), "Ваш пароль от панели администратора: "C_WHITE"%s", password);
    SendClientMessage(playerid, COLOR_SUCCESS, string);
    SendClientMessage(playerid, COLOR_SUCCESS, "Рекомендуется сделать скриншот. Клавиша: "C_WHITE"F8");

    if(admin_info[playerid][admin_level] >= ADM_SPECIAL_ADMIN)
    {
        format(string, sizeof string, "Вы авторизовались в админ-панели как "C_WHITE"%s", admin_ranks_name[admin_info[playerid][admin_level]]);
        return SendClientMessage(playerid, COLOR_SERVER, string);
    }

    new country[64], 
        city[64];

    GetIPCountry(pInfo[playerid][pIP], country, sizeof country);
    GetIPCity(pInfo[playerid][pIP], city, sizeof city);

    if(!pInfo[playerid][pCheckCode])
    {
        format(string, sizeof string , 
                "[A] Администратор %s[%d] авторизовал%s без граф. ключа [IP: %s (%s %s)]", 
            GetName(playerid), playerid, pInfo[playerid][pSex] == 1 ? ("ся") : ("ась"), 
            pInfo[playerid][pIP], country, city
        );
    }
    else
    {
        format(string, sizeof(string), 
                "[A] Администратор %s[%d] авторизовал%s [IP: %s (%s %s)]", 
            GetName(playerid), playerid, pInfo[playerid][pSex] == 1 ? ("ся") : ("ась"), 
            pInfo[playerid][pIP], country, city
        );
     }
     SendAdminMessage(COLOR_SERVER, string);
    return true;
}

stock AuthorizationAdminAccount(playerid, password[])
{
    if(strcmp(admin_info[playerid][admin_password], password))
    {
        SendErrorMessage(playerid, "Вы ввели неверный пароль!");

        admin_attempts_password[playerid] ++;
        if(admin_attempts_password[playerid] > 3)
        {
            admin_attempts_password[playerid] = 0;
            return Kick(playerid);
        }
    }
    else
    {
        new string[72 - 12 + MAX_PLAYER_NAME + 3 + 3 + 16 + 64*2];

        format(string, sizeof string, 
                "UPDATE "T_ADMIN" SET `last_connect` = NOW() WHERE `name` = '%s'", 
            GetName(playerid)
        );
        mysql_tquery(dbHandle, string);

        DisableAntiCheatForAdmin(playerid);
        gAdminLogged[playerid] = true;
        Iter_Add(connected_admins, playerid);
        LoadAdminInformation(playerid);

        if(admin_info[playerid][admin_level] >= ADM_SPECIAL_ADMIN)
        {
            format(string, sizeof string, "Вы авторизовались в админ-панели как %s", admin_ranks_name[admin_info[playerid][admin_level]]);
            return SendClientMessage(playerid, COLOR_SERVER, string);
        }

        new country[64], 
            city[64];

        GetIPCountry(pInfo[playerid][pIP], country, sizeof country);
        GetIPCity(pInfo[playerid][pIP], city, sizeof city);

        if(!pInfo[playerid][pCheckCode])
        {
            format(string, sizeof string , 
                    "[A] Администратор %s[%d] авторизовал%s без граф. ключа [IP: %s (%s %s)]", 
                GetName(playerid), playerid, pInfo[playerid][pSex] == 1 ? ("ся") : ("ась"), 
                pInfo[playerid][pIP], country, city
            );
        }
        else
        {
            format(string, sizeof(string), 
                    "[A] Администратор %s[%d] авторизовал%s [IP: %s (%s %s)]", 
                GetName(playerid), playerid, pInfo[playerid][pSex] == 1 ? ("ся") : ("ась"), 
                pInfo[playerid][pIP], country, city
            );
         }
         SendAdminMessage(COLOR_SERVER, string);
    }
    return true;
}
 

 

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


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

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

  • 0

Проверь в базе данных "registration" меняется на 1 у тебя или нет? И удали mysql_log (при наличии), запусти, залогинься в админке и логи чекни, если будет ошибка с этим (поймёшь по запросу) - скидывай сюда

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


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

[12/19/21 13:31:01] [ERROR] error #1146 while executing query "UPDATE widget SET wValue = '0 / 1000' WHERE wID = 1 LIMIT 1": Table 'gs135944.widget' doesn't exist (F:\lol\pok\gamemodes\evolus.pwn:6420)
[12/19/21 13:31:01] [ERROR] error #1146 while executing query "UPDATE widget SET wValue = '0' WHERE wID = 3 LIMIT 1": Table 'gs135944.widget' doesn't exist (F:\lol\pok\gamemodes\evolus.pwn:6422)
[12/19/21 13:31:16] [ERROR] error #1146 while executing query "UPDATE widget SET wKey = '��� ������� � 13:31:', wValue = '1' WHERE wID = 2 LIMIT 1": Table 'gs135944.widget' doesn't exist (F:\lol\pok\gamemodes\evolus.pwn:136 -> ..\source\lib\nex-ac.inc:3005 -> ..\source\lib\sscanf2.inc:235)
[12/19/21 13:31:57] [ERROR] cache_get_value_name_int: field 'registration' not found (..\source\system\admin\cmd_admin\cmd_alogin.inc:136)
[12/19/21 13:32:04] [ERROR] error #1146 while executing query "UPDATE widget SET wValue = '1 / 1000' WHERE wID = 1 LIMIT 1": Table 'gs135944.widget' doesn't exist (F:\lol\pok\gamemodes\evolus.pwn:6420)
[12/19/21 13:32:04] [ERROR] error #1146 while executing query "UPDATE widget SET wValue = '0' WHERE wID = 3 LIMIT 1": Table 'gs135944.widget' doesn't exist (F:\lol\pok\gamemodes\evolus.pwn:6422)
[12/19/21 13:32:06] [ERROR] error #1054 while executing query "UPDATE admin SET `password` = '123456789011', `last_connect` = NOW(), `registration` = '1' WHERE `name` = 'Alexander_Belov'": Unknown column 'registration' in 'field list' (..\source\system\admin\cmd_admin\cmd_alogin.inc:136 -> ..\source\system\admin\cmd_admin\cmd_alogin.inc:135)
[12/19/21 13:32:06] [ERROR] error #1054 while executing query "UPDATE admin SET `password` = '123456789011', `last_connect` = NOW(), `registration` = '1' WHERE `name` = 'Alexander_Belov'": Unknown column 'registration' in 'field list' (..\source\system\admin\cmd_admin\cmd_alogin.inc:136 -> ..\source\system\admin\cmd_admin\cmd_alogin.inc:135)
[12/19/21 13:32:08] [ERROR] cache_get_value_name_int: field 'registration' not found (..\source\system\admin\cmd_admin\cmd_alogin.inc:136)
[12/19/21 13:32:14] [ERROR] error #1054 while executing query "UPDATE admin SET online_sunday = 8 WHERE ID = 0 LIMIT 1": Unknown column 'ID' in 'where clause' (F:\lol\pok\gamemodes\evolus.pwn:136 -> ..\source\lib\nex-ac.inc:3073 -> ..\source\lib\sscanf2.inc:259)

 

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


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

@Ori 

[12/19/21 13:31:57] [ERROR] cache_get_value_name_int: field 'registration' not found (..\source\system\admin\cmd_admin\cmd_alogin.inc:136)

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


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

@SCRIPTMAN registration его в базе данных нету

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


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

@Ori создай и всё будет сохраняться. тип int, длина значения 1

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


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   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;
      }