Вопросы

Приветствую, у меня такая проблема, я загружаю аккаунт в базу данных, и у меня почему-то шифруется, если я не чего не шифровал, помогите пожалуйста. Шифруется пароль и Email и возможно ник реферала

Вот сам скрин:

 

Сам код: 

    static const fmt_query[] = "INSERT INTO `users` (`name`, `password`, `email`, `ref`, `sex`, `skin`) VALUES ('%s', '%s', '%s', '%s', '%d', '%d')";
    new query[sizeof(fmt_query)+(-2+MAX_PLAYER_NAME)+(-2+65)+(-2+64)+(-2+8)+(-2+1)+(-2+3)];
    format(query, sizeof(query), fmt_query, Name(playerid), PlayerInfo[playerid][pPass], PlayerInfo[playerid][pEmail], PlayerInfo[playerid][pRef], PlayerInfo[playerid][pSex], PlayerInfo[playerid][pSkin]);
    mysql_tquery(dbHandle, query);

 

Снимок экрана (340).png

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


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

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

  • 0

@Flicker, какая кодировка установлена в таблице и какая кодировка установлена для соединения? Первое можно посмотреть в разделе "Операции", второе – стоит взглянуть на код, связанный с соединением.

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


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

Вот таблица

 

Снимок экрана (341).png

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


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

@Flicker, SAMP собран в кодировке Windows-1251 (cp1251). Это означает, что все вводимые (в чате или в диалогах), а также выводимые тексты должны быть в кодировке 1251. Вероятно, получается так, что вы вводите пароль и почту, содержание по меньшей мере один кириллический символ, который, как сами видите, некорректно хранится в базе данных.

 

Если говорить о причинах некорректного отображения, то следует принять во внимание, что в кодировке UTF8 символы кодируются двумя байтами, а в Windows-1251 – одним байтом. И, если латинский алфавит располагается с самого начала в двух этих кодировках (потому и отображается у вас корректно), то кириллица в Windows-1251 начинается с 192 номера, когда в UTF8 – с 1040.

 

Говоря о решении, достаточно просто указать для СУБД и для соединения с ядром СУБД, что вам необходимо cp1251.

  1. В СУБД во вкладке "Операции" выставите cp1251_general_ci. Аналогичную операцию придется проделать для всей базы данных.
  2. При подключении используйте функцию mysql_set_charset_set со значением cp1251.

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


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

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

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

    • Узбек
      От Узбек
      Всем добрый вечер ребят! 
      Я начинающий, сегодня я вам сливаю команду 2(шт) на технические работы
      Ловите 
       
    • nazpol9
      От nazpol9
      Привет всем.

      У меня имеется мод для самп сервера и VPS с Ubuntu, на котором я пытаюсь его запустить.

      В чем суть проблемы: при запуске samp03svr, сервер запускается, но на версии 0.3.DL R-1. Когда я пытаюсь запустить этот же мод локально на Windows, сервер работает на версии 0.3.7 и я могу зайти на него без клиента 0.3.DL.

      Для решения этой проблемы я уже пробовал заменять инклуды и исполнительные файлы теми, что есть в архивах на официальном сайте сампа, перекомпилировал мод, и ничего не изменилось.
       
      #include <a_samp> #include <a_mysql> #include <foreach> #include <Pawn.RakNet> #include <streamer> #include <sscanf2> #include <float2> #include <crashdetect> #include <fmt> #include <a_http> #include <Pawn.CMD> #include <Pawn.Regex> #include <requests> #include <callbacks> #include <MD5> #include <mxdate> #include <TOTP> #include <gvar> #include <md-sort> #include <nex-ac> #include <weapon-config> #include <discord-connector> #include <3DTryg> #include <textdraw-streamer>  
      plugins crashdetect.so streamer.so textdraw-streamer.so sscanf.so pawnraknet.so pawncmd.so mysql.so requests.so profiler.so pawnregex.so TOTP.so gvar.so discord-connector.so

      Если у кого-то будут какие-либо догадки, прошу ими поделиться, если понадобится больше информации - я постараюсь её предоставить.