Форум программистов, компьютерный форум, киберфорум
Java: GUI, графика
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
Заблокирован
1

Кто декомпилировал GUI приложения java поделитесь опытом

02.02.2012, 16:49. Показов 1601. Ответов 9
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть *.jar файл. Там одна формочка. На ней: одно текстовое поле, одна кнопочка и определенный алгоритм который что то делает с введенной строкой.
Задача: понять что же делается со строкой.
Я пытался декомпилить с помощью JD GUI. все вроде бы хорошо, но есть 3 места где определяются строки, но нигде не инициализируются. И вроде как все понятно что делается со строкой... но вот для полной картины не хватает 3-переменных типа String. Откуда они берутся непонятно... Есть байт код.. но в нем честно говоря еще больше непонятно)))

Кто что-то подобное делал, подскажите)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
02.02.2012, 16:49
Ответы с готовыми решениями:

Поделитесь опытом написания приложения
Добрый день. Хочу написать приложение WPF или WinForm, создавать проект WPF или WinForm и там...

Кто создавал службу Windows в Qt, поделитесь опытом
Всем доброго дня! Кто создавал службу Windows в Qt.... поделитесь опытом...

Кто выходил из "сопли-фильра" поделитесь опытом
Два месяца назад сайт www.lival-svet.ru словил "сопли" от гугла. Почитав некоторые советы...

Фрилансеры, кто путешествует и работает удаленно, поделитесь опытом
Сколько вам лет, какой опыт разработки? Сколько долларов зарабатываете, сколько тратите? Я бы...

9
Эксперт Java
4093 / 3827 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 11
02.02.2012, 18:10 2
покажите байт-код метода, в котором используется строка, и еще покажите декомпилированный код метода
1
Заблокирован
02.02.2012, 22:11  [ТС] 3
Java
1
2
3
4
5
6
7
8
9
  public byte[] a = { 77, 11, 99, 10, 33, 9, 2, 8 };
  public static String b;
  public static String c;
  Label d;
  JButton e;
  TextField f;
  public static boolean g;
  public static boolean h;
  private static final String[] z;
- объявление

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    JFrame localJFrame = new JFrame(z[3]);
    this.d = new Label(z[4]);
    this.e = new JButton(z[2]);
    this.f = new TextField("", 30);
    localJFrame.add(this.d);
    localJFrame.add(this.f);
    localJFrame.add(this.e);
    this.e.addActionListener(this);
    localJFrame.setSize(380, 80);
    localJFrame.setLocationRelativeTo(null);
    JFrame.setDefaultLookAndFeelDecorated(true);
    localJFrame.setDefaultCloseOperation(3);
    localJFrame.setLayout(new FlowLayout(3));
    localJFrame.setVisible(true);
    localJFrame.setResizable(false);
- объявление формочки где уже используются переменные

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
public void actionPerformed(ActionEvent paramActionEvent)
  {
    boolean bool = h;
    if (paramActionEvent.getSource() == this.e)
    {
      byte[] arrayOfByte = this.f.getText().getBytes();
      a(arrayOfByte);
      String str = new String(arrayOfByte);
      if (!bool)
      {
        this.f.setText(new String(b));
        if (str.equals(b))
        {
          this.a = arrayOfByte;
          arrayOfByte = c.getBytes();
          a(arrayOfByte);
          this.d.setText(z[1]);
          this.f.setText(new String(arrayOfByte));
          if (!bool)
            return;
        }
      }
      this.f.setText(z[0]);
    }
  }
- функция проверки строки

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
  public void a(byte[] paramArrayOfByte)
  {
    boolean bool = h;
    int i = 0;
    do
    {
      if (i >= paramArrayOfByte.length)
        break;
      paramArrayOfByte[i] = (byte)(paramArrayOfByte[i] ^ this.a[0] ^ this.a[(this.a.length - 1)]);
      i++;
    }
    while (!bool);
  }  public void a(byte[] paramArrayOfByte)
  {
    boolean bool = h;
    int i = 0;
    do
    {
      if (i >= paramArrayOfByte.length)
        break;
      paramArrayOfByte[i] = (byte)(paramArrayOfByte[i] ^ this.a[0] ^ this.a[(this.a.length - 1)]);
      i++;
    }
    while (!bool);
  }
- функция работающая с массивом байтов полученных из строки


Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
 static
  {
    // Byte code:
    //   0: iconst_5
    //   1: anewarray 36    java/lang/String
    //   4: dup
    //   5: iconst_0
    //   6: ldc 45
    //   8: bipush 255
    //   10: goto +46 -> 56
    //   13: aastore
    //   14: dup
    //   15: iconst_1
    //   16: ldc 43
    //   18: iconst_0
    //   19: goto +37 -> 56
    //   22: aastore
    //   23: dup
    //   24: iconst_2
    //   25: ldc 14
    //   27: iconst_1
    //   28: goto +28 -> 56
    //   31: aastore
    //   32: dup
    //   33: iconst_3
    //   34: ldc 7
    //   36: iconst_2
    //   37: goto +19 -> 56
    //   40: aastore
    //   41: dup
    //   42: iconst_4
    //   43: ldc 10
    //   45: iconst_3
    //   46: goto +10 -> 56
    //   49: aastore
    //   50: putstatic 167  Sample:z    [Ljava/lang/String;
    //   53: goto +131 -> 184
    //   56: swap
    //   57: invokevirtual 159  java/lang/String:toCharArray    ()[C
    //   60: dup
    //   61: arraylength
    //   62: swap
    //   63: iconst_0
    //   64: istore_0
    //   65: goto +67 -> 132
    //   68: dup
    //   69: iload_0
    //   70: dup2
    //   71: caload
    //   72: iload_0
    //   73: iconst_5
    //   74: irem
    //   75: tableswitch    default:+49 -> 124, 0:+29->104, 1:+34->109, 2:+39->114, 3:+44->119
    //   105: dload_0
    //   106: goto +20 -> 126
    //   109: bipush 83
    //   111: goto +15 -> 126
    //   114: bipush 7
    //   116: goto +10 -> 126
    //   119: bipush 31
    //   121: goto +5 -> 126
    //   124: bipush 127
    //   126: ixor
    //   127: i2c
    //   128: castore
    //   129: iinc 0 1
    //   132: swap
    //   133: dup_x1
    //   134: iload_0
    //   135: if_icmpgt -67 -> 68
    //   138: new 36    java/lang/String
    //   141: dup_x1
    //   142: swap
    //   143: invokespecial 162 java/lang/String:<init> ([C)V
    //   146: invokevirtual 165 java/lang/String:intern ()Ljava/lang/String;
    //   149: swap
    //   150: pop
    //   151: swap
    //   152: tableswitch   default:+-139 -> 13, 0:+-130->22, 1:+-121->31, 2:+-112->40, 3:+-103->49
    //   185: nop
    //   186: ishl
    //   187: swap
    //   188: invokevirtual 159 java/lang/String:toCharArray    ()[C
    //   191: dup
    //   192: arraylength
    //   193: swap
    //   194: iconst_0
    //   195: istore_0
    //   196: goto +68 -> 264
    //   199: dup
    //   200: iload_0
    //   201: dup2
    //   202: caload
    //   203: iload_0
    //   204: iconst_5
    //   205: irem
    //   206: tableswitch   default:+50 -> 256, 0:+30->236, 1:+35->241, 2:+40->246, 3:+45->251
    //   237: dload_0
    //   238: goto +20 -> 258
    //   241: bipush 83
    //   243: goto +15 -> 258
    //   246: bipush 7
    //   248: goto +10 -> 258
    //   251: bipush 31
    //   253: goto +5 -> 258
    //   256: bipush 127
    //   258: ixor
    //   259: i2c
    //   260: castore
    //   261: iinc 0 1
    //   264: swap
    //   265: dup_x1
    //   266: iload_0
    //   267: if_icmpgt -68 -> 199
    //   270: new 36    java/lang/String
    //   273: dup_x1
    //   274: swap
    //   275: invokespecial 162 java/lang/String:<init> ([C)V
    //   278: invokevirtual 165 java/lang/String:intern ()Ljava/lang/String;
    //   281: swap
    //   282: pop
    //   283: swap
    //   284: tableswitch   default:+27 -> 311, 0:+36->320
    //   305: iaload
    //   306: bipush 255
    //   308: goto -121 -> 187
    //   311: putstatic 38  Sample:b    Ljava/lang/String;
    //   314: ldc 47
    //   316: iconst_0
    //   317: goto -130 -> 187
    //   320: putstatic 42  Sample:c    Ljava/lang/String;
    //   323: return
  }
- байт код
0
Эксперт Java
4093 / 3827 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 11
03.02.2012, 06:33 4
Я не понял что за байт-код мне показали, но точно не байт-код этих методов.
Вот вы писали
3 места где определяются строки
где эти места?

покажите тот метод и байт-код того метода
1
Заблокирован
03.02.2012, 09:33  [ТС] 5
Java
1
2
3
4
  
public static String b;
public static String c;
private static final String[] z;
z - не нужна оттуда берутся только строки для объектов формы...
нужны только b и c.

байт код был закомментированный в коде который мне выдал декомпилятор... а как узнать байт код этого приложения? может у меня декомпилятор не очень?
0
Эксперт Java
4093 / 3827 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 11
03.02.2012, 14:29 6
Есть декомплилятор - JD(GUI)
Есть дизассемблер - javap
вот скормите class файл одному и другому, и покажите.

Добавлено через 2 часа 21 минуту
выложите class файл, хотя бы, наконец. Очень интересно.
1
Заблокирован
03.02.2012, 15:25  [ТС] 7
хм... а что то проясняется... java.rar - тут файлики

там в байткоде есть

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
6:  ldc #45; //String q!hq b|\rC'+?G?&
...
16: ldc #43; //String e<cz_O =
...
25: ldc #14; //String i
...
34: ldc #7; //String aN
...
43: ldc #10; //String u6dmRsnlE
...
304:    ldc #46; //String z7?s#(I
...
314:    ldc #47; //String T0o}V.
Причем первые пять используются для элементов Формы.
6 - Сообщение о том что строка введена неверно
16 - имя метки при правильно введенном
25 - "ОК"
34 - "GUI"
43 - имя метки при неправильно введенном....

только вот как их расшифровать?
0
Заблокирован
08.02.2012, 15:37  [ТС] 8
ктонибуууудь.... помогииииите, уже ниче в голову не идеь
0
Эксперт Java
4093 / 3827 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 11
09.02.2012, 15:12 9
Цитата Сообщение от alex_bojik Посмотреть сообщение
ктонибуууудь.... помогииииите, уже ниче в голову не идеь
Вот. Поразмял мозги)
это статическая часть инициализации класса
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
static {
        String[] expr1 = new String[5];
        expr1[0] = "q!hq b|\rC'+?G?&";
        expr1[1] = "e<cz_O =";
        expr1[2] = "i";
        expr1[3] = "aN";
        expr1[4] = "u6dmRsnlE";
        
        for (int k = 0; k < 5; k++) {
            char[] expr57 = expr1[k].toCharArray();
            for (int i =0; i<expr57.length; i++) {
                char expr71 = expr57[i];
                int irem = i % 5;
 
                int exprSW74;
                switch (irem) {
                    case 0: exprSW74 = 38; break;
                    case 1: exprSW74 = 83; break;
                    case 2: exprSW74 = 7; break;
                    case 3: exprSW74 = 31; break;
                    default: exprSW74 = 127; break;
                }
 
                expr57[i] = (char)(exprSW74 ^ expr71);
            }
            expr1[k] = new String(expr57);
        }
        z = expr1;
        
        
        int a = -1;
        do {
            char[] c304;
            if (a==0)
                c304 = "T0o}V.".toCharArray();
            else
                c304 = "z7?s#(I".toCharArray();
 
            for (int i =0; i<c304.length; i++) {
                char expr71 = c304[i];
                int irem = i % 5;
 
                int exprSW74;
                switch (irem) {
                    case 0: exprSW74 = 38; break;
                    case 1: exprSW74 = 83; break;
                    case 2: exprSW74 = 7; break;
                    case 3: exprSW74 = 31; break;
                    default: exprSW74 = 127; break;
                }
 
                c304[i] = (char)(exprSW74 ^ expr71);
            }
            if (a==0)
                c = new String(c304);
            else
                b = new String(c304);
            a++;
        }
        while (a!=1);
    }
1
Заблокирован
10.02.2012, 15:54  [ТС] 10
собрал))) осталось только расшифровать что же делается с введенной строкой, как получится результат напишу))

Добавлено через 6 часов 3 минуты
получилось

Значит так.
при декомпилировании использовалась
JD GUI - с помощью него получился примерный код
оказалось что есть небольшая хитрость при начальном определении строковых переменных.
Эту хитрость очень помог разгадать turbanoff за что ему огромное спасибо!!!
с помощью этого класса... определяем значения z[],b,c которые в исходном коде представлены как-то не красиво... я делал это путем вывода после определения на заголовок формы... но впринципе можно и было и код поразбирать.
Далее идет
Java
1
2
3
4
5
6
7
8
9
10
11
        this.f.setText(new String(b));
        if (str.equals(b))
        {
          this.a = arrayOfByte;
          arrayOfByte = c.getBytes();
          a(arrayOfByte);
          this.d.setText(z[1]);
          this.f.setText(new String(arrayOfByte));
          if (!bool)
            return;
        }
- основная загвоздка... если вкратце здесь проверяется правильная ли строка введена... инвертируем условие... далее вводим уже определенное значение строки b и нажимаем ОК... процедура срабатывает... потому что мы ввели условие и выводит нам еще какую-то строку... мы снова ее копируем запускаем программку иии... вот он долгожданный ключик - цель самого декомпилирования....

P.S. зачем все это нужно? Дело в том, что это одно из заданий ИТ-квеста.... Если кому интересно ищите тут
0
10.02.2012, 15:54
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.02.2012, 15:54
Помогаю со студенческими работами здесь

Fine reader engine кто использовал? Поделитесь опытом
Хочу узнать может кто сталкивался, как в графическом файле, либо pdf файле найти нужную информацию...

FireMonkey(FMX) - кто серьезно использовал, поделитесь опытом
Добрый день. Я давно программирую на Delphi и часто слышал про FireMonkey. Но раньше не было...

Поделитесь опытом кто реально объединял сети через Mikrotik
Вобщем облазил кучу сайтов, пробовал разные методы, но все время косяк какой то был с объединением,...

Кто самостоятельно, с нуля стал хорошим программистом, поделитесь опытом
Расскажите, как вы изучали свой первый яп. Сколько времени у вас это заняло? Какие книги читали?...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru