Вернуться   CoderX :: Forums > Lineage II > L2PacketHack > Разработка
Войти через OpenID

Разработка Раздел для совместной разработки/доработки программы

Чат (Новых сообщений с момента вашего последнего визита нет)
Загрузка...
Задавайте ваши вопросы на форуме. Чат предназначен для небольших разговоров.
 
Ответ
 
Опции темы Опции просмотра
Старый 13.02.2012, 14:44   #1
Местный
 
Регистрация: 23.02.2009
Сообщений: 319
Сказал Спасибо: 72
Имеет 60 спасибок в 45 сообщенях
Kilatif пока неопределено
По умолчанию

Цитата:
Проблема теперь в другом... пакет который приходит 186, но данные другие от делфи).
Так он и будет приходить разный) Он будет приходить всегда разный, потому что каждый раз в нем приходят разные RSA-key, SessionID и BlowFishKey )
Kilatif вне форума   Ответить с цитированием
Старый 13.02.2012, 16:13   #2
Новичок
 
Регистрация: 12.02.2012
Сообщений: 27
Сказал Спасибо: 8
Имеет 0 спасибок в 0 сообщенях
ErgoZ пока неопределено
По умолчанию

У меня другая проблема)) я запутался немного.
Тоже пишу на яве чат-клиент. Так как я запутался, скажите правильно ли я думаю:

Подключаюсь к серверу и получаю примерно такой пакет:

02-13 10:34:04.991: I/System.out(472): BA00D139D82F2A4002CCFF622488E4B92F4D8C9FD87DFFA459 92F106EEE2E80ECB58A8545471CE687B6CDA41D9245B611BB0 2A17E29CC8FFE881B2921E48685738E3E933CD655849B8FCED 69150E4612BB2061BBB5C6C2E8DC2E406F714F6E5EEFD3B99C 66A6D72492A61832D4B574F8120156AE8175A46C14274B78F8 7AECB50C8FFD2CF4AEE6E63BE19F8C0F6F2E34907CAEC62768 AAB6D45DDF13D2DBC90B877D48CE68610756087308564ECDC5 1124174228D4EC14701414

Далее отсекаю у него размер пакета (ba00) и получившийся пакет без первых 2 байт я должен декодить по блоуфишу с начальным ключём, правильно?
Тогда я получаю:

02-13 10:34:05.021: I/System.out(472): 4580A1F93794E8BC6B523C3B95239FD1530F626B0574949395 E97080C912DBB2F872AE1847A8717CB6D5D882FFC7856363FB 8ECC3014FF634B639CE48622886AE51F15DF43DB777542FEA3 BBA1869AA055DEEFF1798BA6277B73F0D39F6894E02B474CDA 22436B8CA29D43218CF5AA6F34EC28497854E0E1D12601FAFA A01B328308722E1B10570299F03C51727BCDC451B69A894B99 1C8B0C145E9DD8D62B49F82B2D62EAD85F0CE4F6B78188BB45 44C5B149F46A39D21423EF


Дальше я по идее должен получить ключ для XOR, т.е. взять 178-181 байты (из оставшихся 184, т.к. отрезал 2 байта размера), или другие, если допустим не считать уже отрезанные 2 байта размера? Вот тут я не понимаю, запутался. Просто xkor тут такие значения писал http://coderx.ru/showpost.php?p=30849&postcount=53

Какие всё таки байты брать для ключа ксора?
Правильно ли я понимаю что ксорить надо будет по 4 байта начиная с первого и заканчивая размером пакета минус размер ксор ключа (т.е. 4 байта).

Ещё загвоздка в том, что не могу найти описание того как ксорить на яве, я так понял через символ ^, но он ругается на то что его нельзя использовать с типом byte, в котором у меня пакет и ключ. Где можно найти инфу по этому поводу? в исходниках серва не смог более менее путное найти.


Сильно не пинайти, кодить на яве начал неделю назад.
ErgoZ вне форума   Ответить с цитированием
Старый 13.02.2012, 16:44   #3
Местный
 
Регистрация: 23.02.2009
Сообщений: 319
Сказал Спасибо: 72
Имеет 60 спасибок в 45 сообщенях
Kilatif пока неопределено
По умолчанию

ErgoZ, что бы долго не писать, сразу пришлю код =) (C#)

Код:
        public static byte[] AntiXor(byte[] s)
        {
            long key, b;
            int i;
            byte[] b_temp;

            b_temp = new byte[4];

            i = s.Length - 8;

            key = BitConverter.ToInt32(s, i);
            while (i >= 7)
            {
                i = i - 4;
                b = BitConverter.ToInt32(s, i);
                b = b ^ key;
                key = key - b;

                Array.Copy(BitConverter.GetBytes((Int32)b), 0, b_temp, 0, 4); 
                Array.Copy(b_temp, 0, s, i, 4);
            }

            return s;
        }
Kilatif вне форума   Ответить с цитированием
Старый 13.02.2012, 17:02   #4
Новичок
 
Регистрация: 12.02.2012
Сообщений: 27
Сказал Спасибо: 8
Имеет 0 спасибок в 0 сообщенях
ErgoZ пока неопределено
По умолчанию

в эту ф-цию подставляем пакет с размером или без него? с типом пакета или без него?
ErgoZ вне форума   Ответить с цитированием
Старый 13.02.2012, 17:10   #5
Местный
 
Регистрация: 23.02.2009
Сообщений: 319
Сказал Спасибо: 72
Имеет 60 спасибок в 45 сообщенях
Kilatif пока неопределено
По умолчанию

ErgoZ, только без размера пакета.
Kilatif вне форума   Ответить с цитированием
Старый 14.02.2012, 01:20   #6
Пользователь
 
Регистрация: 29.01.2012
Адрес: г. Минск
Сообщений: 64
Сказал Спасибо: 10
Имеет 5 спасибок в 5 сообщенях
Tin-moon пока неопределено
По умолчанию

To Kilatif :
Дошел до LS_init.
Код:
procedure LS_init(buff: array of byte; Len: integer);
begin
  if Len<8 then exit;
  Move(buff[3],SessionID,4);
  if Len>=155 then begin
    SetLength(RSA_key,128);
    Move(buff[11],RSA_key[1],128);
    ToLog('RSA Key changed');
  end;
  if Len>=171 then begin
    SetLength(bf_key,16);
    Move(buff[155],bf_key[1],16);
    bf.Init(bf_key);
    ToLog('BlowFish key changed');
  end;
  //sending AuthGG packet
  AuthGameGuard;
end;
bf.Init(bf_key); - это новая инициализация? или переинициализация в начале ? И вообще с какой нужно работать дальше? или с обееми?
Tin-moon вне форума   Ответить с цитированием
Старый 13.02.2012, 17:16   #7
Новичок
 
Регистрация: 12.02.2012
Сообщений: 27
Сказал Спасибо: 8
Имеет 0 спасибок в 0 сообщенях
ErgoZ пока неопределено
По умолчанию

Спасибо большое, переписал под яву, ща буду пробовать
ErgoZ вне форума   Ответить с цитированием
Старый 13.02.2012, 18:55   #8
Новичок
 
Регистрация: 06.05.2008
Сообщений: 5
Сказал Спасибо: 1
Имеет 0 спасибок в 0 сообщенях
Winners пока неопределено
По умолчанию

Если я правильно понял то ты хочешь программу на манер вот этой Увы это единственный ресурс где я смог ее найти пользовался ею оч давно еще под интерлюд. Позже она перестала обновлятся и так проект канул в летах. Не знаю есть ли возможность найти исходники или переделать эиу но вобщем посмотреть что за зверь можна.
Winners вне форума   Ответить с цитированием
Старый 13.02.2012, 21:59   #9
Пользователь
 
Регистрация: 29.01.2012
Адрес: г. Минск
Сообщений: 64
Сказал Спасибо: 10
Имеет 5 спасибок в 5 сообщенях
Tin-moon пока неопределено
По умолчанию

Цитата:
Сообщение от Winners Посмотреть сообщение
Если я правильно понял то ты хочешь программу на манер вот этой Увы это единственный ресурс где я смог ее найти пользовался ею оч давно еще под интерлюд. Позже она перестала обновлятся и так проект канул в летах. Не знаю есть ли возможность найти исходники или переделать эиу но вобщем посмотреть что за зверь можна.
Эта программа работает по другому принципу, там перехват API функций клиента, насколько я помню.

Добавлено через 1 минуту
Цитата:
Сообщение от ErgoZ Посмотреть сообщение
Подключаюсь к серверу и получаю примерно такой пакет:

02-13 10:34:04.991: I/System.out(472): BA00D139D82F2A4002CCFF622488E4B92F4D8C9FD87DFFA459 92F106EEE2E80ECB58A8545471CE687B6CDA41D9245B611BB0 2A17E29CC8FFE881B2921E48685738E3E933CD655849B8FCED 69150E4612BB2061BBB5C6C2E8DC2E406F714F6E5EEFD3B99C 66A6D72492A61832D4B574F8120156AE8175A46C14274B78F8 7AECB50C8FFD2CF4AEE6E63BE19F8C0F6F2E34907CAEC62768 AAB6D45DDF13D2DBC90B877D48CE68610756087308564ECDC5 1124174228D4EC14701414
Как ты читаешь? Лучше код в студию)

Последний раз редактировалось Tin-moon, 13.02.2012 в 21:59. Причина: Добавлено сообщение
Tin-moon вне форума   Ответить с цитированием
Старый 13.02.2012, 20:13   #10
Новичок
 
Регистрация: 12.02.2012
Сообщений: 27
Сказал Спасибо: 8
Имеет 0 спасибок в 0 сообщенях
ErgoZ пока неопределено
По умолчанию

да, я пишу аналог этой софтины, но под явой. Чисто для себя под андроид.

Kilatif, странно работает антиксор который ты написал... особенно странно для меня:
key = key - b; - зачем из ключа вычитать весь пакет?
Array.Copy(BitConverter.GetBytes((Int32)b), 0, b_temp, 0, 4); тут тоже не совсем понятно что это делает, у нас ведь в итоге весь пакет получается 4 байтным в итоге, разве нет?

Или может я криво переписал это дело под андроид? просто на яве нет бит ковертера))) пришлось гуглить аналоги, нашёл пару функций:


PHP код:
public static int ToInt32(byte[] bytesint offset) {
          
int ret 0;
          for (
int i=0i<&& i+offset<bytes.lengthi++) {
            
ret <<= 8;
            
ret |= (int)bytes[i] & 0xFF;
          }
          return 
ret;
        } 
PHP код:
 public static byte[] toBytes(long valboolean bigEndian)
    {
        
byte[] res = new byte[8];
        if (
bigEndian)
        {
            
res[0] = (byte)(val>>56&0xFF);
            
res[1] = (byte)(val>>48&0xFF);
            
res[2] = (byte)(val>>40&0xFF);
            
res[3] = (byte)(val>>32&0xFF);
            
res[4] = (byte)(val>>24&0xFF);
            
res[5] = (byte)(val>>16&0xFF);
            
res[6] = (byte)(val>>8&0xFF);
            
res[7] = (byte)(val&0xFF);
        } else
        {
            
res[7] = (byte)(val>>56&0xFF);
            
res[6] = (byte)(val>>48&0xFF);
            
res[5] = (byte)(val>>40&0xFF);
            
res[4] = (byte)(val>>32&0xFF);
            
res[3] = (byte)(val>>24&0xFF);
            
res[2] = (byte)(val>>16&0xFF);
            
res[1] = (byte)(val>>8&0xFF);
            
res[0] = (byte)(val&0xFF);
        }
        return 
res;
    } 
в итоге у меня на выводе после антиксора: [B@40538170
не понимаю где косяк а так хочется чат на андроиде иметь)))
ErgoZ вне форума   Ответить с цитированием
Ответ

  CoderX :: Forums > Lineage II > L2PacketHack > Разработка



Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


Часовой пояс GMT +4, время: 16:54.

vBulletin style designed by MSC Team.
Powered by vBulletin® Version 3.6.11
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd. Перевод: zCarot
Locations of visitors to this page
Rambler's Top100

Вы хотите чувствовать себя в безопасности? чоп Белган обеспечит её!