Π²ΡΠ²Π΅Π΄Π΅Π½ΠΈΠ΅
Π ΠΊΡΠ°Ρ Π½Π° ΠΌΠ°ΡΡ Π½ΠΈΠ΅
ΠΡΠ΅Π΄ΠΈ ΠΈΠ·Π²Π΅ΡΡΠ½ΠΎ Π²ΡΠ΅ΠΌΠ΅ UC Browser Π±Π΅ΡΠ΅ ΡΠ΅ΠΊΠ»Π°ΠΌΠΈΡΠ°Π½ ΠΈ ΡΠ°Π·ΠΏΡΠΎΡΡΡΠ°Π½ΡΠ²Π°Π½ ΠΌΠ½ΠΎΠ³ΠΎ Π°Π³ΡΠ΅ΡΠΈΠ²Π½ΠΎ: ΡΠΎΠΉ Π±Π΅ΡΠ΅ ΠΈΠ½ΡΡΠ°Π»ΠΈΡΠ°Π½ Π½Π° ΠΏΠΎΡΡΠ΅Π±ΠΈΡΠ΅Π»ΡΠΊΠΈ ΡΡΡΡΠΎΠΉΡΡΠ²Π° Ρ ΠΏΠΎΠΌΠΎΡΡΠ° Π½Π° Π·Π»ΠΎΠ²ΡΠ΅Π΄Π΅Π½ ΡΠΎΡΡΡΠ΅Ρ, ΡΠ°Π·ΠΏΡΠΎΡΡΡΠ°Π½ΡΠ²Π°Π½ ΠΎΡ ΡΠ°Π·Π»ΠΈΡΠ½ΠΈ ΡΠ°ΠΉΡΠΎΠ²Π΅ ΠΏΠΎΠ΄ ΠΏΡΠΈΠΊΡΠΈΡΠΈΠ΅ΡΠΎ Π½Π° Π²ΠΈΠ΄Π΅ΠΎ ΡΠ°ΠΉΠ»ΠΎΠ²Π΅ (Ρ.Π΅. ΠΏΠΎΡΡΠ΅Π±ΠΈΡΠ΅Π»ΠΈΡΠ΅ ΡΠΈ ΠΌΠΈΡΠ»Π΅Ρ
Π°, ΡΠ΅ ΠΈΠ·ΡΠ΅Π³Π»ΡΡ Π½Π°ΠΏΡΠΈΠΌΠ΅Ρ ΠΏΠΎΡΠ½ΠΎ Π²ΠΈΠ΄Π΅ΠΎ, Π½ΠΎ Π²ΠΌΠ΅ΡΡΠΎ ΡΠΎΠ²Π° ΠΏΠΎΠ»ΡΡΠΈ APK Ρ ΡΠΎΠ·ΠΈ Π±ΡΠ°ΡΠ·ΡΡ), ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° ΡΡΡΠ°ΡΠ½ΠΈ Π±Π°Π½Π΅ΡΠΈ ΡΡΡ ΡΡΠΎΠ±ΡΠ΅Π½ΠΈΡ, ΡΠ΅ Π±ΡΠ°ΡΠ·ΡΡΡΡ Π΅ ΠΎΡΡΠ°ΡΡΠ», ΡΡΠ·Π²ΠΈΠΌ ΠΈ ΠΏΠΎΠ΄ΠΎΠ±Π½ΠΈ Π½Π΅ΡΠ°. Π ΠΎΡΠΈΡΠΈΠ°Π»Π½Π°ΡΠ° Π³ΡΡΠΏΠ° Π½Π° UC Browser Π²ΡΠ² VK ΠΈΠΌΠ°
ΠΡΠΌ ΠΌΠΎΠΌΠ΅Π½ΡΠ° Π½Π° ΠΏΠΈΡΠ°Π½Π΅ UC Browser ΠΈΠΌΠ° Π½Π°Π΄ 500 000 000 ΠΈΠ½ΡΡΠ°Π»Π°ΡΠΈΠΈ Π² Google Play. Π’ΠΎΠ²Π° Π΅ Π²ΠΏΠ΅ΡΠ°ΡΠ»ΡΠ²Π°ΡΠΎ - ΡΠ°ΠΌΠΎ Google Chrome ΠΈΠΌΠ° ΠΏΠΎΠ²Π΅ΡΠ΅. Π‘ΡΠ΅Π΄ ΡΠ΅ΡΠ΅Π½Π·ΠΈΠΈΡΠ΅ ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° Π²ΠΈΠ΄ΠΈΡΠ΅ Π΄ΠΎΡΡΠ° ΠΎΠΏΠ»Π°ΠΊΠ²Π°Π½ΠΈΡ ΠΎΡΠ½ΠΎΡΠ½ΠΎ ΡΠ΅ΠΊΠ»Π°ΠΌΠΈ ΠΈ ΠΏΡΠ΅Π½Π°ΡΠΎΡΠ²Π°Π½ΠΈΡ ΠΊΡΠΌ Π½ΡΠΊΠΎΠΈ ΠΏΡΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΡ Π² Google Play. Π’ΠΎΠ²Π° Π±Π΅ΡΠ΅ ΠΏΡΠΈΡΠΈΠ½Π°ΡΠ° Π·Π° Π½Π°ΡΠ΅ΡΠΎ ΠΏΡΠΎΡΡΠ²Π°Π½Π΅: ΡΠ΅ΡΠΈΡ
ΠΌΠ΅ Π΄Π° Π²ΠΈΠ΄ΠΈΠΌ Π΄Π°Π»ΠΈ UC Browser ΠΏΡΠ°Π²ΠΈ Π½Π΅ΡΠΎ Π»ΠΎΡΠΎ. Π ΡΠ΅ ΠΎΠΊΠ°Π·Π°, ΡΠ΅ Π³ΠΎ ΠΏΡΠ°Π²ΠΈ!
Π ΠΊΠΎΠ΄Π° Π½Π° ΠΏΡΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅ΡΠΎ Π±Π΅ΡΠ΅ ΠΎΡΠΊΡΠΈΡΠ° Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡ Π·Π° ΠΈΠ·ΡΠ΅Π³Π»ΡΠ½Π΅ ΠΈ ΡΡΠ°ΡΡΠΈΡΠ°Π½Π΅ Π½Π° ΠΈΠ·ΠΏΡΠ»Π½ΠΈΠΌ ΠΊΠΎΠ΄,
ΠΡΠΈΡΠΊΠΎ Π½Π°ΠΏΠΈΡΠ°Π½ΠΎ ΠΏΠΎ-Π΄ΠΎΠ»Ρ Π΅ ΠΏΡΠΈΠ»ΠΎΠΆΠΈΠΌΠΎ Π·Π° Π²Π΅ΡΡΠΈΡΡΠ° Π½Π° UC Browser, ΠΊΠΎΡΡΠΎ Π±Π΅ΡΠ΅ Π½Π°Π»ΠΈΡΠ½Π° Π² Google Play ΠΏΠΎ Π²ΡΠ΅ΠΌΠ΅ Π½Π° ΠΏΡΠΎΡΡΠ²Π°Π½Π΅ΡΠΎ:
package: com.UCMobile.intl
versionName: 12.10.8.1172
versionCode: 10598
sha1 APK-ΡΠ°ΠΉΠ»Π°: f5edb2243413c777172f6362876041eb0c3a928c
ΠΠ΅ΠΊΡΠΎΡ Π½Π° Π°ΡΠ°ΠΊΠ°
Π ΠΌΠ°Π½ΠΈΡΠ΅ΡΡΠ° Π½Π° UC Browser ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° Π½Π°ΠΌΠ΅ΡΠΈΡΠ΅ ΡΡΠ»ΡΠ³Π° Ρ ΡΠ°Π·Π±ΠΈΡΠ°Π΅ΠΌΠΎ ΠΈΠΌΠ΅ com.uc.deployment.UpgradeDeployService.
<service android_exported="false" android_name="com.uc.deployment.UpgradeDeployService" android_process=":deploy" />
ΠΠΎΠ³Π°ΡΠΎ ΡΠ°Π·ΠΈ ΡΡΠ»ΡΠ³Π° ΡΡΠ°ΡΡΠΈΡΠ°, Π±ΡΠ°ΡΠ·ΡΡΡΡ ΠΏΡΠ°Π²ΠΈ POST Π·Π°ΡΠ²ΠΊΠ° ΠΊΡΠΌ
Π’Π°ΠΊΠ° ΡΠ΅, ΠΊΠΎΠ³Π°ΡΠΎ ΠΏΠΎΡΡΠ΅Π±ΠΈΡΠ΅Π» ΠΈΡΠΊΠ° Π΄Π° ΠΎΡΠ²ΠΎΡΠΈ PDF Π΄ΠΈΡΠ΅ΠΊΡΠ½ΠΎ Π² Π±ΡΠ°ΡΠ·ΡΡΠ°, Π² ΡΡΠ°ΡΠΈΠΊΠ° ΠΌΠΎΠ³Π°Ρ Π΄Π° ΡΠ΅ Π²ΠΈΠ΄ΡΡ ΡΠ»Π΅Π΄Π½ΠΈΡΠ΅ Π·Π°ΡΠ²ΠΊΠΈ:
ΠΡΡΠ²ΠΎ ΠΈΠΌΠ° POST Π·Π°ΡΠ²ΠΊΠ° ΠΊΡΠΌ
ΠΠ·ΡΠ΅Π³Π»Ρ ΡΠ΅ Π°ΡΡ
ΠΈΠ² Ρ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° Π·Π° ΠΏΡΠ΅Π³Π»Π΅Π΄ Π½Π° PDF ΠΈ ΠΎΡΠΈΡ ΡΠΎΡΠΌΠ°ΡΠΈ. ΠΠΎΠ³ΠΈΡΠ½ΠΎ Π΅ Π΄Π° ΡΠ΅ ΠΏΡΠ΅Π΄ΠΏΠΎΠ»ΠΎΠΆΠΈ, ΡΠ΅ ΠΏΡΡΠ²Π°ΡΠ° Π·Π°ΡΠ²ΠΊΠ° ΠΏΡΠ΅Π΄Π°Π²Π° ΠΈΠ½ΡΠΎΡΠΌΠ°ΡΠΈΡ Π·Π° ΡΠΈΡΡΠ΅ΠΌΠ°ΡΠ° (Π½Π°ΠΉ-ΠΌΠ°Π»ΠΊΠΎ Π°ΡΡ
ΠΈΡΠ΅ΠΊΡΡΡΠ°ΡΠ° Π·Π° ΠΏΡΠ΅Π΄ΠΎΡΡΠ°Π²ΡΠ½Π΅ Π½Π° Π½Π΅ΠΎΠ±Ρ
ΠΎΠ΄ΠΈΠΌΠ°ΡΠ° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°), Π° Π² ΠΎΡΠ³ΠΎΠ²ΠΎΡ Π½Π° Π½Π΅Ρ Π±ΡΠ°ΡΠ·ΡΡΡΡ ΠΏΠΎΠ»ΡΡΠ°Π²Π° Π½ΡΠΊΠ°ΠΊΠ²Π° ΠΈΠ½ΡΠΎΡΠΌΠ°ΡΠΈΡ Π·Π° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°ΡΠ°, ΠΊΠΎΡΡΠΎ ΡΡΡΠ±Π²Π° Π΄Π° Π±ΡΠ΄Π΅ ΠΈΠ·ΡΠ΅Π³Π»Π΅Π½Π°: Π°Π΄ΡΠ΅ΡΠ° ΠΈ Π΅Π²Π΅Π½ΡΡΠ°Π»Π½ΠΎ , Π½Π΅ΡΠΎ Π΄ΡΡΠ³ΠΎ. ΠΡΠΎΠ±Π»Π΅ΠΌΡΡ Π΅, ΡΠ΅ ΡΠ°Π·ΠΈ Π·Π°ΡΠ²ΠΊΠ° Π΅ ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π°.
ΠΠ°ΡΠ²ΠΊΠ° Π·Π° ΡΡΠ°Π³ΠΌΠ΅Π½Ρ
Π€ΡΠ°Π³ΠΌΠ΅Π½Ρ Π½Π° ΠΎΡΠ³ΠΎΠ²ΠΎΡΠ°
Π‘Π°ΠΌΠ°ΡΠ° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° Π΅ ΠΏΠ°ΠΊΠ΅ΡΠΈΡΠ°Π½Π° Π² ZIP ΠΈ Π½Π΅ Π΅ ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π°.
ΠΠΎΡΡΡΡΠ΅ΡΠ΅ ΠΊΠΎΠ΄ Π·Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½Π΅ Π½Π° ΡΡΠ°ΡΠΈΠΊΠ°
ΠΠ΅ΠΊΠ° ΡΠ΅ ΠΎΠΏΠΈΡΠ°ΠΌΠ΅ Π΄Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°ΠΌΠ΅ ΠΎΡΠ³ΠΎΠ²ΠΎΡΠ° Π½Π° ΡΡΡΠ²ΡΡΠ°. ΠΠ΅ΠΊΠ° Π΄Π° ΡΠ°Π·Π³Π»Π΅Π΄Π°ΠΌΠ΅ ΠΊΠΎΠ΄Π° Π½Π° ΠΊΠ»Π°ΡΠ° com.uc.deployment.UpgradeDeployService: ΠΎΡ ΠΌΠ΅ΡΠΎΠ΄ onStartCommand ΠΎΡΠΈΠ΄Π΅ΡΠ΅ Π½Π° com.uc.deployment.bx, ΠΈ ΠΎΡ Π½Π΅Π³ΠΎ ΠΊΡΠΌ com.uc.browser.core.dcfe:
public final void e(l arg9) {
int v4_5;
String v3_1;
byte[] v3;
byte[] v1 = null;
if(arg9 == null) {
v3 = v1;
}
else {
v3_1 = arg9.iGX.ipR;
StringBuilder v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]product:");
v4.append(arg9.iGX.ipR);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]version:");
v4.append(arg9.iGX.iEn);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]upgrade_type:");
v4.append(arg9.iGX.mMode);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]force_flag:");
v4.append(arg9.iGX.iEo);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]silent_mode:");
v4.append(arg9.iGX.iDQ);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]silent_type:");
v4.append(arg9.iGX.iEr);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]silent_state:");
v4.append(arg9.iGX.iEp);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]silent_file:");
v4.append(arg9.iGX.iEq);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]apk_md5:");
v4.append(arg9.iGX.iEl);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]download_type:");
v4.append(arg9.mDownloadType);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]download_group:");
v4.append(arg9.mDownloadGroup);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]download_path:");
v4.append(arg9.iGH);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]apollo_child_version:");
v4.append(arg9.iGX.iEx);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]apollo_series:");
v4.append(arg9.iGX.iEw);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]apollo_cpu_arch:");
v4.append(arg9.iGX.iEt);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]apollo_cpu_vfp3:");
v4.append(arg9.iGX.iEv);
v4 = new StringBuilder("[");
v4.append(v3_1);
v4.append("]apollo_cpu_vfp:");
v4.append(arg9.iGX.iEu);
ArrayList v3_2 = arg9.iGX.iEz;
if(v3_2 != null && v3_2.size() != 0) {
Iterator v3_3 = v3_2.iterator();
while(v3_3.hasNext()) {
Object v4_1 = v3_3.next();
StringBuilder v5 = new StringBuilder("[");
v5.append(((au)v4_1).getName());
v5.append("]component_name:");
v5.append(((au)v4_1).getName());
v5 = new StringBuilder("[");
v5.append(((au)v4_1).getName());
v5.append("]component_ver_name:");
v5.append(((au)v4_1).aDA());
v5 = new StringBuilder("[");
v5.append(((au)v4_1).getName());
v5.append("]component_ver_code:");
v5.append(((au)v4_1).gBl);
v5 = new StringBuilder("[");
v5.append(((au)v4_1).getName());
v5.append("]component_req_type:");
v5.append(((au)v4_1).gBq);
}
}
j v3_4 = new j();
m.b(v3_4);
h v4_2 = new h();
m.b(v4_2);
ay v5_1 = new ay();
v3_4.hS("");
v3_4.setImsi("");
v3_4.hV("");
v5_1.bPQ = v3_4;
v5_1.bPP = v4_2;
v5_1.yr(arg9.iGX.ipR);
v5_1.gBF = arg9.iGX.mMode;
v5_1.gBI = arg9.iGX.iEz;
v3_2 = v5_1.gAr;
c.aBh();
v3_2.add(g.fs("os_ver", c.getRomInfo()));
v3_2.add(g.fs("processor_arch", com.uc.b.a.a.c.getCpuArch()));
v3_2.add(g.fs("cpu_arch", com.uc.b.a.a.c.Pb()));
String v4_3 = com.uc.b.a.a.c.Pd();
v3_2.add(g.fs("cpu_vfp", v4_3));
v3_2.add(g.fs("net_type", String.valueOf(com.uc.base.system.a.Jo())));
v3_2.add(g.fs("fromhost", arg9.iGX.iEm));
v3_2.add(g.fs("plugin_ver", arg9.iGX.iEn));
v3_2.add(g.fs("target_lang", arg9.iGX.iEs));
v3_2.add(g.fs("vitamio_cpu_arch", arg9.iGX.iEt));
v3_2.add(g.fs("vitamio_vfp", arg9.iGX.iEu));
v3_2.add(g.fs("vitamio_vfp3", arg9.iGX.iEv));
v3_2.add(g.fs("plugin_child_ver", arg9.iGX.iEx));
v3_2.add(g.fs("ver_series", arg9.iGX.iEw));
v3_2.add(g.fs("child_ver", r.aVw()));
v3_2.add(g.fs("cur_ver_md5", arg9.iGX.iEl));
v3_2.add(g.fs("cur_ver_signature", SystemHelper.getUCMSignature()));
v3_2.add(g.fs("upgrade_log", i.bjt()));
v3_2.add(g.fs("silent_install", String.valueOf(arg9.iGX.iDQ)));
v3_2.add(g.fs("silent_state", String.valueOf(arg9.iGX.iEp)));
v3_2.add(g.fs("silent_file", arg9.iGX.iEq));
v3_2.add(g.fs("silent_type", String.valueOf(arg9.iGX.iEr)));
v3_2.add(g.fs("cpu_archit", com.uc.b.a.a.c.Pc()));
v3_2.add(g.fs("cpu_set", SystemHelper.getCpuInstruction()));
boolean v4_4 = v4_3 == null || !v4_3.contains("neon") ? false : true;
v3_2.add(g.fs("neon", String.valueOf(v4_4)));
v3_2.add(g.fs("cpu_cores", String.valueOf(com.uc.b.a.a.c.Jl())));
v3_2.add(g.fs("ram_1", String.valueOf(com.uc.b.a.a.h.Po())));
v3_2.add(g.fs("totalram", String.valueOf(com.uc.b.a.a.h.OL())));
c.aBh();
v3_2.add(g.fs("rom_1", c.getRomInfo()));
v4_5 = e.getScreenWidth();
int v6 = e.getScreenHeight();
StringBuilder v7 = new StringBuilder();
v7.append(v4_5);
v7.append("*");
v7.append(v6);
v3_2.add(g.fs("ss", v7.toString()));
v3_2.add(g.fs("api_level", String.valueOf(Build$VERSION.SDK_INT)));
v3_2.add(g.fs("uc_apk_list", SystemHelper.getUCMobileApks()));
Iterator v4_6 = arg9.iGX.iEA.entrySet().iterator();
while(v4_6.hasNext()) {
Object v6_1 = v4_6.next();
v3_2.add(g.fs(((Map$Entry)v6_1).getKey(), ((Map$Entry)v6_1).getValue()));
}
v3 = v5_1.toByteArray();
}
if(v3 == null) {
this.iGY.iGI.a(arg9, "up_encode", "yes", "fail");
return;
}
v4_5 = this.iGY.iGw ? 0x1F : 0;
if(v3 == null) {
}
else {
v3 = g.i(v4_5, v3);
if(v3 == null) {
}
else {
v1 = new byte[v3.length + 16];
byte[] v6_2 = new byte[16];
Arrays.fill(v6_2, 0);
v6_2[0] = 0x5F;
v6_2[1] = 0;
v6_2[2] = ((byte)v4_5);
v6_2[3] = -50;
System.arraycopy(v6_2, 0, v1, 0, 16);
System.arraycopy(v3, 0, v1, 16, v3.length);
}
}
if(v1 == null) {
this.iGY.iGI.a(arg9, "up_encrypt", "yes", "fail");
return;
}
if(TextUtils.isEmpty(this.iGY.mUpgradeUrl)) {
this.iGY.iGI.a(arg9, "up_url", "yes", "fail");
return;
}
StringBuilder v0 = new StringBuilder("[");
v0.append(arg9.iGX.ipR);
v0.append("]url:");
v0.append(this.iGY.mUpgradeUrl);
com.uc.browser.core.d.c.i v0_1 = this.iGY.iGI;
v3_1 = this.iGY.mUpgradeUrl;
com.uc.base.net.e v0_2 = new com.uc.base.net.e(new com.uc.browser.core.d.c.i$a(v0_1, arg9));
v3_1 = v3_1.contains("?") ? v3_1 + "&dataver=pb" : v3_1 + "?dataver=pb";
n v3_5 = v0_2.uc(v3_1);
m.b(v3_5, false);
v3_5.setMethod("POST");
v3_5.setBodyProvider(v1);
v0_2.b(v3_5);
this.iGY.iGI.a(arg9, "up_null", "yes", "success");
this.iGY.iGI.b(arg9);
}
ΠΠΈΠΆΠ΄Π°ΠΌΠ΅ ΡΠΎΡΠΌΠΈΡΠ°Π½Π΅ΡΠΎ Π½Π° POST Π·Π°ΡΠ²ΠΊΠ° ΡΡΠΊ. ΠΠ±ΡΡΡΠ°ΠΌΠ΅ Π²Π½ΠΈΠΌΠ°Π½ΠΈΠ΅ Π½Π° ΡΡΠ·Π΄Π°Π²Π°Π½Π΅ΡΠΎ Π½Π° ΠΌΠ°ΡΠΈΠ² ΠΎΡ 16 Π±Π°ΠΉΡΠ° ΠΈ Π½Π΅Π³ΠΎΠ²ΠΎΡΠΎ ΠΏΠΎΠΏΡΠ»Π²Π°Π½Π΅: 0x5F, 0, 0x1F, -50 (=0xCE). Π‘ΡΠ²ΠΏΠ°Π΄Π° Ρ ΡΠΎΠ²Π°, ΠΊΠΎΠ΅ΡΠΎ Π²ΠΈΠ΄ΡΡ ΠΌΠ΅ Π² Π·Π°ΡΠ²ΠΊΠ°ΡΠ° ΠΏΠΎ-Π³ΠΎΡΠ΅.
Π ΡΡΡΠΈΡ ΠΊΠ»Π°Ρ ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° Π²ΠΈΠ΄ΠΈΡΠ΅ Π²Π»ΠΎΠΆΠ΅Π½ ΠΊΠ»Π°Ρ, ΠΊΠΎΠΉΡΠΎ ΠΈΠΌΠ° Π΄ΡΡΠ³ ΠΈΠ½ΡΠ΅ΡΠ΅ΡΠ΅Π½ ΠΌΠ΅ΡΠΎΠ΄:
public final void a(l arg10, byte[] arg11) {
f v0 = this.iGQ;
StringBuilder v1 = new StringBuilder("[");
v1.append(arg10.iGX.ipR);
v1.append("]:UpgradeSuccess");
byte[] v1_1 = null;
if(arg11 == null) {
}
else if(arg11.length < 16) {
}
else {
if(arg11[0] != 0x60 && arg11[3] != 0xFFFFFFD0) {
goto label_57;
}
int v3 = 1;
int v5 = arg11[1] == 1 ? 1 : 0;
if(arg11[2] != 1 && arg11[2] != 11) {
if(arg11[2] == 0x1F) {
}
else {
v3 = 0;
}
}
byte[] v7 = new byte[arg11.length - 16];
System.arraycopy(arg11, 16, v7, 0, v7.length);
if(v3 != 0) {
v7 = g.j(arg11[2], v7);
}
if(v7 == null) {
goto label_57;
}
if(v5 != 0) {
v1_1 = g.P(v7);
goto label_57;
}
v1_1 = v7;
}
label_57:
if(v1_1 == null) {
v0.iGY.iGI.a(arg10, "up_decrypt", "yes", "fail");
return;
}
q v11 = g.b(arg10, v1_1);
if(v11 == null) {
v0.iGY.iGI.a(arg10, "up_decode", "yes", "fail");
return;
}
if(v0.iGY.iGt) {
v0.d(arg10);
}
if(v0.iGY.iGo != null) {
v0.iGY.iGo.a(0, ((o)v11));
}
if(v0.iGY.iGs) {
v0.iGY.a(((o)v11));
v0.iGY.iGI.a(v11, "up_silent", "yes", "success");
v0.iGY.iGI.a(v11);
return;
}
v0.iGY.iGI.a(v11, "up_silent", "no", "success");
}
}
ΠΠ΅ΡΠΎΠ΄ΡΡ ΠΏΡΠΈΠ΅ΠΌΠ° ΠΌΠ°ΡΠΈΠ² ΠΎΡ Π±Π°ΠΉΡΠΎΠ²Π΅ ΠΊΠ°ΡΠΎ Π²Ρ
ΠΎΠ΄ ΠΈ ΠΏΡΠΎΠ²Π΅ΡΡΠ²Π° Π΄Π°Π»ΠΈ Π½ΡΠ»Π΅Π²ΠΈΡΡ Π±Π°ΠΉΡ Π΅ 0x60 ΠΈΠ»ΠΈ ΡΡΠ΅ΡΠΈΡΡ Π±Π°ΠΉΡ Π΅ 0xD0, Π° Π²ΡΠΎΡΠΈΡΡ Π±Π°ΠΉΡ Π΅ 1, 11 ΠΈΠ»ΠΈ 0x1F. Π Π°Π·Π³Π»Π΅ΠΆΠ΄Π°ΠΌΠ΅ ΠΎΡΠ³ΠΎΠ²ΠΎΡΠ° ΠΎΡ ΡΡΡΠ²ΡΡΠ°: Π½ΡΠ»Π΅Π²ΠΈΡΡ Π±Π°ΠΉΡ Π΅ 0x60, Π²ΡΠΎΡΠΈΡΡ Π΅ 0x1F, ΡΡΠ΅ΡΠΈΡΡ Π΅ 0x60. ΠΠ²ΡΡΠΈ ΠΊΠ°ΡΠΎ ΡΠΎΠ²Π°, ΠΎΡ ΠΊΠΎΠ΅ΡΠΎ ΡΠ΅ Π½ΡΠΆΠ΄Π°Π΅ΠΌ. Π‘ΡΠ΄Π΅ΠΉΠΊΠΈ ΠΏΠΎ ΡΠ΅Π΄ΠΎΠ²Π΅ΡΠ΅ (βup_decryptβ, Π½Π°ΠΏΡΠΈΠΌΠ΅Ρ), ΡΡΠΊ ΡΡΡΠ±Π²Π° Π΄Π° ΡΠ΅ ΠΈΠ·Π²ΠΈΠΊΠ° ΠΌΠ΅ΡΠΎΠ΄, ΠΊΠΎΠΉΡΠΎ ΡΠ΅ Π΄Π΅ΡΠΈΡΡΠΈΡΠ° ΠΎΡΠ³ΠΎΠ²ΠΎΡΠ° Π½Π° ΡΡΡΠ²ΡΡΠ°.
ΠΠ° ΠΏΡΠ΅ΠΌΠΈΠ½Π΅ΠΌ ΠΊΡΠΌ ΠΌΠ΅ΡΠΎΠ΄Π° gj. ΠΠΌΠ°ΠΉΡΠ΅ ΠΏΡΠ΅Π΄Π²ΠΈΠ΄, ΡΠ΅ ΠΏΡΡΠ²ΠΈΡΡ Π°ΡΠ³ΡΠΌΠ΅Π½Ρ Π΅ Π±Π°ΠΉΡΡΡ ΠΏΡΠΈ ΠΎΡΠΌΠ΅ΡΡΠ²Π°Π½Π΅ 2 (Ρ.Π΅. 0x1F Π² Π½Π°ΡΠΈΡ ΡΠ»ΡΡΠ°ΠΉ), Π° Π²ΡΠΎΡΠΈΡΡ Π΅ ΠΎΡΠ³ΠΎΠ²ΠΎΡΡΡ Π½Π° ΡΡΡΠ²ΡΡΠ° Π±Π΅Π·
ΠΏΡΡΠ²ΠΈΡΠ΅ 16 Π±Π°ΠΉΡΠ°.
public static byte[] j(int arg1, byte[] arg2) {
if(arg1 == 1) {
arg2 = c.c(arg2, c.adu);
}
else if(arg1 == 11) {
arg2 = m.aF(arg2);
}
else if(arg1 != 0x1F) {
}
else {
arg2 = EncryptHelper.decrypt(arg2);
}
return arg2;
}
ΠΡΠ΅Π²ΠΈΠ΄Π½ΠΎ ΡΡΠΊ ΠΈΠ·Π±ΠΈΡΠ°ΠΌΠ΅ Π°Π»Π³ΠΎΡΠΈΡΡΠΌ Π·Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½Π΅ ΠΈ ΡΡΡΠΈΡ Π±Π°ΠΉΡ, ΠΊΠΎΠΉΡΠΎ Π΅ Π² Π½Π°ΡΠΈΡ
ΡΠ»ΡΡΠ°ΠΉ, ΡΠ°Π²Π΅Π½ Π½Π° 0x1F, ΠΎΠ±ΠΎΠ·Π½Π°ΡΠ°Π²Π° Π΅Π΄Π½Π° ΠΎΡ ΡΡΠΈ Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΈ ΠΎΠΏΡΠΈΠΈ.
ΠΡΠΎΠ΄ΡΠ»ΠΆΠ°Π²Π°ΠΌΠ΅ Π΄Π° Π°Π½Π°Π»ΠΈΠ·ΠΈΡΠ°ΠΌΠ΅ ΠΊΠΎΠ΄Π°. Π‘Π»Π΅Π΄ Π½ΡΠΊΠΎΠ»ΠΊΠΎ ΡΠΊΠΎΠΊΠ° ΡΠ΅ ΠΎΠ·ΠΎΠ²Π°Π²Π°ΠΌΠ΅ Π² ΠΌΠ΅ΡΠΎΠ΄ Ρ ΡΠ°Π·Π±ΠΈΡΠ°ΡΠΎ ΡΠ΅ ΠΈΠΌΠ΅ Π΄Π΅ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π΅BytesByKey.
Π’ΡΠΊ ΠΎΡΠ΅ Π΄Π²Π° Π±Π°ΠΉΡΠ° ΡΠ΅ ΠΎΡΠ΄Π΅Π»ΡΡ ΠΎΡ Π½Π°ΡΠΈΡ ΠΎΡΠ³ΠΎΠ²ΠΎΡ ΠΈ ΠΎΡ ΡΡΡ ΡΠ΅ ΠΏΠΎΠ»ΡΡΠ°Π²Π° Π½ΠΈΠ·. Π―ΡΠ½ΠΎ Π΅, ΡΠ΅ ΠΏΠΎ ΡΠΎΠ·ΠΈ Π½Π°ΡΠΈΠ½ ΡΠ΅ ΠΈΠ·Π±ΠΈΡΠ° ΠΊΠ»ΡΡΡΡ Π·Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½Π΅ Π½Π° ΡΡΠΎΠ±ΡΠ΅Π½ΠΈΠ΅ΡΠΎ.
private static byte[] decryptBytesByKey(byte[] bytes) {
byte[] v0 = null;
if(bytes != null) {
try {
if(bytes.length < EncryptHelper.PREFIX_BYTES_SIZE) {
}
else if(bytes.length == EncryptHelper.PREFIX_BYTES_SIZE) {
return v0;
}
else {
byte[] prefix = new byte[EncryptHelper.PREFIX_BYTES_SIZE]; // 2 Π±Π°ΠΉΡΠ°
System.arraycopy(bytes, 0, prefix, 0, prefix.length);
String keyId = c.ayR().d(ByteBuffer.wrap(prefix).getShort()); // ΠΡΠ±ΠΎΡ ΠΊΠ»ΡΡΠ°
if(keyId == null) {
return v0;
}
else {
a v2 = EncryptHelper.ayL();
if(v2 == null) {
return v0;
}
else {
byte[] enrypted = new byte[bytes.length - EncryptHelper.PREFIX_BYTES_SIZE];
System.arraycopy(bytes, EncryptHelper.PREFIX_BYTES_SIZE, enrypted, 0, enrypted.length);
return v2.l(keyId, enrypted);
}
}
}
}
catch(SecException v7_1) {
EncryptHelper.handleDecryptException(((Throwable)v7_1), v7_1.getErrorCode());
return v0;
}
catch(Throwable v7) {
EncryptHelper.handleDecryptException(v7, 2);
return v0;
}
}
return v0;
}
ΠΠ»Π΅Π΄Π°ΠΉΠΊΠΈ Π½Π°ΠΏΡΠ΅Π΄, ΠΎΡΠ±Π΅Π»ΡΠ·Π²Π°ΠΌΠ΅, ΡΠ΅ Π½Π° ΡΠΎΠ·ΠΈ Π΅ΡΠ°ΠΏ Π²ΡΠ΅ ΠΎΡΠ΅ Π½Π΅ ΠΏΠΎΠ»ΡΡΠ°Π²Π°ΠΌΠ΅ ΠΊΠ»ΡΡ, Π° ΡΠ°ΠΌΠΎ Π½Π΅Π³ΠΎΠ²ΠΈΡ βΠΈΠ΄Π΅Π½ΡΠΈΡΠΈΠΊΠ°ΡΠΎΡβ. ΠΠΎΠ»ΡΡΠ°Π²Π°Π½Π΅ΡΠΎ Π½Π° ΠΊΠ»ΡΡΠ° Π΅ ΠΌΠ°Π»ΠΊΠΎ ΠΏΠΎ-ΡΠ»ΠΎΠΆΠ½ΠΎ.
Π ΡΠ»Π΅Π΄Π²Π°ΡΠΈΡ ΠΌΠ΅ΡΠΎΠ΄ ΠΊΡΠΌ ΡΡΡΠ΅ΡΡΠ²ΡΠ²Π°ΡΠΈΡΠ΅ ΡΠ΅ Π΄ΠΎΠ±Π°Π²ΡΡ ΠΎΡΠ΅ Π΄Π²Π° ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΡΠ°, ΠΊΠΎΠ΅ΡΠΎ Π³ΠΈ ΠΏΡΠ°Π²ΠΈ ΡΠ΅ΡΠΈΡΠΈ: ΠΌΠ°Π³ΠΈΡΠ΅ΡΠΊΠΎΡΠΎ ΡΠΈΡΠ»ΠΎ 16, ΠΈΠ΄Π΅Π½ΡΠΈΡΠΈΠΊΠ°ΡΠΎΡΡΡ Π½Π° ΠΊΠ»ΡΡΠ°, ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½ΠΈΡΠ΅ Π΄Π°Π½Π½ΠΈ ΠΈ Π½Π΅ΡΠ°Π·Π±ΠΈΡΠ°Π΅ΠΌ Π½ΠΈΠ· (Π² Π½Π°ΡΠΈΡ ΡΠ»ΡΡΠ°ΠΉ ΠΏΡΠ°Π·Π΅Π½).
public final byte[] l(String keyId, byte[] encrypted) throws SecException {
return this.ayJ().staticBinarySafeDecryptNoB64(16, keyId, encrypted, "");
}
Π‘Π»Π΅Π΄ ΡΠ΅ΡΠΈΡ ΠΎΡ ΠΏΡΠ΅Ρ ΠΎΠ΄ΠΈ ΡΡΠΈΠ³Π°ΠΌΠ΅ Π΄ΠΎ ΠΌΠ΅ΡΠΎΠ΄Π° staticBinarySafeDecryptNoB64 ΠΈΠ½ΡΠ΅ΡΡΠ΅ΠΉΡ com.alibaba.wireless.security.open.staticdataencrypt.IStaticDataEncryptComponent. ΠΡΠΌΠ° ΠΊΠ»Π°ΡΠΎΠ²Π΅ Π² ΠΎΡΠ½ΠΎΠ²Π½ΠΈΡ ΠΊΠΎΠ΄ Π½Π° ΠΏΡΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅ΡΠΎ, ΠΊΠΎΠΈΡΠΎ ΡΠ΅Π°Π»ΠΈΠ·ΠΈΡΠ°Ρ ΡΠΎΠ·ΠΈ ΠΈΠ½ΡΠ΅ΡΡΠ΅ΠΉΡ. ΠΡΠ² ΡΠ°ΠΉΠ»Π° ΠΈΠΌΠ° ΡΠ°ΠΊΡΠ² ΠΊΠ»Π°Ρ lib/armeabi-v7a/libsgmain.so, ΠΊΠΎΠ΅ΡΠΎ Π²ΡΡΡΠ½ΠΎΡΡ Π½Π΅ Π΅ .so, Π° .jar. ΠΠ΅ΡΠΎΠ΄ΡΡ, ΠΊΠΎΠΉΡΠΎ Π½ΠΈ ΠΈΠ½ΡΠ΅ΡΠ΅ΡΡΠ²Π°, ΡΠ΅ ΠΈΠ·ΠΏΡΠ»Π½ΡΠ²Π° ΠΏΠΎ ΡΠ»Π΅Π΄Π½ΠΈΡ Π½Π°ΡΠΈΠ½:
package com.alibaba.wireless.security.a.i;
// ...
public class a implements IStaticDataEncryptComponent {
private ISecurityGuardPlugin a;
// ...
private byte[] a(int mode, int magicInt, int xzInt, String keyId, byte[] encrypted, String magicString) {
return this.a.getRouter().doCommand(10601, new Object[]{Integer.valueOf(mode), Integer.valueOf(magicInt), Integer.valueOf(xzInt), keyId, encrypted, magicString});
}
// ...
private byte[] b(int magicInt, String keyId, byte[] encrypted, String magicString) {
return this.a(2, magicInt, 0, keyId, encrypted, magicString);
}
// ...
public byte[] staticBinarySafeDecryptNoB64(int magicInt, String keyId, byte[] encrypted, String magicString) throws SecException {
if(keyId != null && keyId.length() > 0 && magicInt >= 0 && magicInt < 19 && encrypted != null && encrypted.length > 0) {
return this.b(magicInt, keyId, encrypted, magicString);
}
throw new SecException("", 301);
}
//...
}
Π’ΡΠΊ Π½Π°ΡΠΈΡΡ ΡΠΏΠΈΡΡΠΊ ΠΎΡ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ ΡΠ΅ Π΄ΠΎΠΏΡΠ»Π²Π° Ρ ΠΎΡΠ΅ Π΄Π²Π΅ ΡΠ΅Π»ΠΈ ΡΠΈΡΠ»Π°: 2 ΠΈ 0. Π‘ΡΠ΄Π΅ΠΉΠΊΠΈ ΠΏΠΎ
Π²ΡΠΈΡΠΊΠΎ, 2 ΠΎΠ·Π½Π°ΡΠ°Π²Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½Π΅, ΠΊΠ°ΠΊΡΠΎ Π² ΠΌΠ΅ΡΠΎΠ΄Π° doFinal ΡΠΈΡΡΠ΅ΠΌΠ΅Π½ ΠΊΠ»Π°Ρ javax.crypto.Cipher. Π Π²ΡΠΈΡΠΊΠΎ ΡΠΎΠ²Π° ΡΠ΅ ΠΏΡΠ΅Ρ
Π²ΡΡΠ»Ρ Π½Π° ΠΎΠΏΡΠ΅Π΄Π΅Π»Π΅Π½ ΡΡΡΠ΅Ρ Ρ Π½ΠΎΠΌΠ΅Ρ 10601 - ΡΠΎΠ²Π° ΡΠ²Π½ΠΎ Π΅ Π½ΠΎΠΌΠ΅ΡΡΡ Π½Π° ΠΊΠΎΠΌΠ°Π½Π΄Π°ΡΠ°.
Π‘Π»Π΅Π΄ ΡΠ»Π΅Π΄Π²Π°ΡΠ°ΡΠ° Π²Π΅ΡΠΈΠ³Π° ΠΎΡ ΠΏΡΠ΅Ρ ΠΎΠ΄ΠΈ Π½Π°ΠΌΠΈΡΠ°ΠΌΠ΅ ΠΊΠ»Π°Ρ, ΠΊΠΎΠΉΡΠΎ ΠΈΠΌΠΏΠ»Π΅ΠΌΠ΅Π½ΡΠΈΡΠ° ΠΈΠ½ΡΠ΅ΡΡΠ΅ΠΉΡΠ° IRouterComponent ΠΈ ΠΌΠ΅ΡΠΎΠ΄ doCommand:
package com.alibaba.wireless.security.mainplugin;
import com.alibaba.wireless.security.framework.IRouterComponent;
import com.taobao.wireless.security.adapter.JNICLibrary;
public class a implements IRouterComponent {
public a() {
super();
}
public Object doCommand(int arg2, Object[] arg3) {
return JNICLibrary.doCommandNative(arg2, arg3);
}
}
Π ΡΡΡΠΎ ΠΈ ΠΊΠ»Π°ΡΠ° JNICLibrary, Π² ΠΊΠΎΠΉΡΠΎ Π΅ Π΄Π΅ΠΊΠ»Π°ΡΠΈΡΠ°Π½ Π½Π°ΡΠΈΠ²Π½ΠΈΡΡ ΠΌΠ΅ΡΠΎΠ΄ doCommandNative:
package com.taobao.wireless.security.adapter;
public class JNICLibrary {
public static native Object doCommandNative(int arg0, Object[] arg1);
}
Π’ΠΎΠ²Π° ΠΎΠ·Π½Π°ΡΠ°Π²Π°, ΡΠ΅ ΡΡΡΠ±Π²Π° Π΄Π° Π½Π°ΠΌΠ΅ΡΠΈΠΌ ΠΌΠ΅ΡΠΎΠ΄ Π² ΡΠΎΠ±ΡΡΠ²Π΅Π½ΠΈΡ ΠΊΠΎΠ΄ doCommandNative. Π ΡΡΠΊ Π·Π°ΠΏΠΎΡΠ²Π° Π·Π°Π±Π°Π²Π»Π΅Π½ΠΈΠ΅ΡΠΎ.
ΠΠ±ΡΡΡΠΊΠ°ΡΠΈΡ Π½Π° ΠΌΠ°ΡΠΈΠ½Π½ΠΈΡ ΠΊΠΎΠ΄
ΠΡΠ² ΡΠ°ΠΉΠ»Π° libsgmain.so (ΠΊΠΎΠ΅ΡΠΎ Π²ΡΡΡΠ½ΠΎΡΡ Π΅ .jar ΠΈ Π² ΠΊΠΎΠ΅ΡΠΎ ΠΎΡΠΊΡΠΈΡ ΠΌΠ΅ ΠΈΠ·ΠΏΡΠ»Π½Π΅Π½ΠΈΠ΅ΡΠΎ Π½Π° Π½ΡΠΊΠΎΠΈ ΠΈΠ½ΡΠ΅ΡΡΠ΅ΠΉΡΠΈ, ΡΠ²ΡΡΠ·Π°Π½ΠΈ Ρ ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π΅ ΡΠΎΡΠ½ΠΎ ΠΏΠΎ-Π³ΠΎΡΠ΅) ΠΈΠΌΠ° Π΅Π΄Π½Π° ΡΠΎΠ±ΡΡΠ²Π΅Π½Π° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°: libsgmainso-6.4.36.so. ΠΡΠ²Π°ΡΡΠΌΠ΅ Π³ΠΎ Π² IDA ΠΈ ΠΏΠΎΠ»ΡΡΠ°Π²Π°ΠΌΠ΅ ΠΊΡΠΏ Π΄ΠΈΠ°Π»ΠΎΠ³ΠΎΠ²ΠΈ ΠΏΡΠΎΠ·ΠΎΡΡΠΈ Ρ Π³ΡΠ΅ΡΠΊΠΈ. ΠΡΠΎΠ±Π»Π΅ΠΌΡΡ Π΅, ΡΠ΅ ΡΠ°Π±Π»ΠΈΡΠ°ΡΠ° ΡΡΡ Π·Π°Π³Π»Π°Π²ΠΊΠΈ Π½Π° ΡΠ΅ΠΊΡΠΈΠΈ Π΅ Π½Π΅Π²Π°Π»ΠΈΠ΄Π½Π°. Π’ΠΎΠ²Π° ΡΠ΅ ΠΏΡΠ°Π²ΠΈ Π½Π°ΡΠΎΡΠ½ΠΎ, Π·Π° Π΄Π° ΡΠ΅ ΡΡΠ»ΠΎΠΆΠ½ΠΈ Π°Π½Π°Π»ΠΈΠ·ΡΡ.
ΠΠΎ Π½Π΅ Π΅ Π½Π΅ΠΎΠ±Ρ
ΠΎΠ΄ΠΈΠΌΠΎ: Π·Π° Π΄Π° Π·Π°ΡΠ΅Π΄ΠΈΡΠ΅ ΠΏΡΠ°Π²ΠΈΠ»Π½ΠΎ ELF ΡΠ°ΠΉΠ» ΠΈ Π΄Π° Π³ΠΎ Π°Π½Π°Π»ΠΈΠ·ΠΈΡΠ°ΡΠ΅, Π΅ Π΄ΠΎΡΡΠ°ΡΡΡΠ½Π° ΡΠ°Π±Π»ΠΈΡΠ° ΡΡΡ Π·Π°Π³Π»Π°Π²ΠΊΠΈ Π½Π° ΠΏΡΠΎΠ³ΡΠ°ΠΌΠ°ΡΠ°. Π‘Π»Π΅Π΄ΠΎΠ²Π°ΡΠ΅Π»Π½ΠΎ Π½ΠΈΠ΅ ΠΏΡΠΎΡΡΠΎ ΠΈΠ·ΡΡΠΈΠ²Π°ΠΌΠ΅ ΡΠ°Π±Π»ΠΈΡΠ°ΡΠ° ΡΡΡ ΡΠ΅ΠΊΡΠΈΠΈ, ΠΊΠ°ΡΠΎ Π½ΡΠ»ΠΈΡΠ°ΠΌΠ΅ ΡΡΠΎΡΠ²Π΅ΡΠ½ΠΈΡΠ΅ ΠΏΠΎΠ»Π΅ΡΠ° Π² Π·Π°Π³Π»Π°Π²ΠΊΠ°ΡΠ°.
ΠΡΠ²ΠΎΡΠ΅ΡΠ΅ ΠΎΡΠ½ΠΎΠ²ΠΎ ΡΠ°ΠΉΠ»Π° Π² IDA.
ΠΠΌΠ° Π΄Π²Π° Π½Π°ΡΠΈΠ½Π° Π΄Π° ΠΊΠ°ΠΆΠ΅ΡΠ΅ Π½Π° Π²ΠΈΡΡΡΠ°Π»Π½Π°ΡΠ° ΠΌΠ°ΡΠΈΠ½Π° Π½Π° Java ΠΊΡΠ΄Π΅ ΡΠΎΡΠ½ΠΎ Π² ΡΠΎΠ±ΡΡΠ²Π΅Π½Π°ΡΠ° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° ΡΠ΅ Π½Π°ΠΌΠΈΡΠ° ΠΈΠ·ΠΏΡΠ»Π½Π΅Π½ΠΈΠ΅ΡΠΎ Π½Π° ΠΌΠ΅ΡΠΎΠ΄, Π΄Π΅ΠΊΠ»Π°ΡΠΈΡΠ°Π½ Π² ΠΊΠΎΠ΄Π° Π½Π° Java ΠΊΠ°ΡΠΎ Π΅ΡΡΠ΅ΡΡΠ²Π΅Π½. ΠΡΡΠ²ΠΈΡΡ Π΅ Π΄Π° ΠΌΡ ΡΠ΅ Π΄Π°Π΄Π΅ ΠΈΠΌΠ΅ Π½Π° Π²ΠΈΠ΄Π° Java_package_name_ClassName_MethodName.
ΠΡΠΎΡΠΎΡΠΎ Π΅ Π΄Π° Π³ΠΎ ΡΠ΅Π³ΠΈΡΡΡΠΈΡΠ°ΡΠ΅ ΠΏΡΠΈ Π·Π°ΡΠ΅ΠΆΠ΄Π°Π½Π΅ Π½Π° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°ΡΠ° (Π²ΡΠ² ΡΡΠ½ΠΊΡΠΈΡΡΠ° JNI_OnLoad)
ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°ΠΉΠΊΠΈ ΠΈΠ·Π²ΠΈΠΊΠ²Π°Π½Π΅ Π½Π° ΡΡΠ½ΠΊΡΠΈΡ Π Π΅Π³ΠΈΡΡΡΠΈΡΠ°ΠΉΡΠ΅ ΡΠ΅.
Π Π½Π°ΡΠΈΡ ΡΠ»ΡΡΠ°ΠΉ, Π°ΠΊΠΎ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°ΠΌΠ΅ ΠΏΡΡΠ²ΠΈΡ ΠΌΠ΅ΡΠΎΠ΄, ΠΈΠΌΠ΅ΡΠΎ ΡΡΡΠ±Π²Π° Π΄Π° Π±ΡΠ΄Π΅ ΡΠ°ΠΊΠ°: Java_com_taobao_wireless_security_adapter_JNICLibrary_doCommandNative.
Π‘ΡΠ΅Π΄ Π΅ΠΊΡΠΏΠΎΡΡΠΈΡΠ°Π½ΠΈΡΠ΅ ΡΡΠ½ΠΊΡΠΈΠΈ Π½ΡΠΌΠ° ΡΠ°ΠΊΠ°Π²Π° ΡΡΠ½ΠΊΡΠΈΡ, ΠΊΠΎΠ΅ΡΠΎ ΠΎΠ·Π½Π°ΡΠ°Π²Π°, ΡΠ΅ ΡΡΡΠ±Π²Π° Π΄Π° ΠΏΠΎΡΡΡΡΠΈΡΠ΅ ΠΏΠΎΠ²ΠΈΠΊΠ²Π°Π½Π΅ Π Π΅Π³ΠΈΡΡΡΠΈΡΠ°ΠΉΡΠ΅ ΡΠ΅.
ΠΠ° ΠΎΡΠΈΠ΄Π΅ΠΌ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° JNI_OnLoad ΠΈ Π²ΠΈΠΆΠ΄Π°ΠΌΠ΅ ΡΠ°Π·ΠΈ ΡΠ½ΠΈΠΌΠΊΠ°:
ΠΠ°ΠΊΠ²ΠΎ ΡΡΠ°Π²Π° ΡΡΠΊ? ΠΠ° ΠΏΡΡΠ² ΠΏΠΎΠ³Π»Π΅Π΄ Π½Π°ΡΠ°Π»ΠΎΡΠΎ ΠΈ ΠΊΡΠ°ΡΡ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° ΡΠ° ΡΠΈΠΏΠΈΡΠ½ΠΈ Π·Π° ARM Π°ΡΡ
ΠΈΡΠ΅ΠΊΡΡΡΠ°ΡΠ°. ΠΡΡΠ²Π°ΡΠ° ΠΈΠ½ΡΡΡΡΠΊΡΠΈΡ Π² ΡΡΠ΅ΠΊΠ° ΡΡΡ
ΡΠ°Π½ΡΠ²Π° ΡΡΠ΄ΡΡΠΆΠ°Π½ΠΈΠ΅ΡΠΎ Π½Π° ΡΠ΅Π³ΠΈΡΡΡΠΈΡΠ΅, ΠΊΠΎΠΈΡΠΎ ΡΡΠ½ΠΊΡΠΈΡΡΠ° ΡΠ΅ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° Π² ΡΠ²ΠΎΡΡΠ° ΡΠ°Π±ΠΎΡΠ° (Π² ΡΠΎΠ·ΠΈ ΡΠ»ΡΡΠ°ΠΉ R0, R1 ΠΈ R2), ΠΊΠ°ΠΊΡΠΎ ΠΈ ΡΡΠ΄ΡΡΠΆΠ°Π½ΠΈΠ΅ΡΠΎ Π½Π° ΡΠ΅Π³ΠΈΡΡΡΡΠ° LR, ΠΊΠΎΠΉΡΠΎ ΡΡΠ΄ΡΡΠΆΠ° Π°Π΄ΡΠ΅ΡΠ° Π·Π° Π²ΡΡΡΠ°Π½Π΅ ΠΎΡ ΡΡΠ½ΠΊΡΠΈΡΡΠ° . ΠΠΎΡΠ»Π΅Π΄Π½Π°ΡΠ° ΠΈΠ½ΡΡΡΡΠΊΡΠΈΡ Π²ΡΠ·ΡΡΠ°Π½ΠΎΠ²ΡΠ²Π° Π·Π°ΠΏΠΈΡΠ°Π½ΠΈΡΠ΅ ΡΠ΅Π³ΠΈΡΡΡΠΈ, Π° Π°Π΄ΡΠ΅ΡΡΡ Π·Π° Π²ΡΡΡΠ°Π½Π΅ Π²Π΅Π΄Π½Π°Π³Π° ΡΠ΅ ΠΏΠΎΡΡΠ°Π²Ρ Π² ΡΠ΅Π³ΠΈΡΡΡΡΠ° Π½Π° ΠΊΠΎΠΌΠΏΡΡΡΡΠ° - ΠΏΠΎ ΡΠΎΠ·ΠΈ Π½Π°ΡΠΈΠ½ ΡΠ΅ Π²ΡΡΡΠ° ΠΎΡ ΡΡΠ½ΠΊΡΠΈΡΡΠ°. ΠΠΎ Π°ΠΊΠΎ ΡΠ΅ Π²Π³Π»Π΅Π΄Π°ΡΠ΅ Π²Π½ΠΈΠΌΠ°ΡΠ΅Π»Π½ΠΎ, ΡΠ΅ Π·Π°Π±Π΅Π»Π΅ΠΆΠΈΡΠ΅, ΡΠ΅ ΠΏΡΠ΅Π΄ΠΏΠΎΡΠ»Π΅Π΄Π½Π°ΡΠ° ΠΈΠ½ΡΡΡΡΠΊΡΠΈΡ ΠΏΡΠΎΠΌΠ΅Π½Ρ Π°Π΄ΡΠ΅ΡΠ° Π·Π° Π²ΡΡΡΠ°Π½Π΅, ΡΡΡ
ΡΠ°Π½Π΅Π½ Π² ΡΡΠ΅ΠΊΠ°. ΠΠ΅ΠΊΠ° ΠΈΠ·ΡΠΈΡΠ»ΠΈΠΌ ΠΊΠ°ΠΊΠ²ΠΎ ΡΠ΅ Π±ΡΠ΄Π΅ ΡΠ»Π΅Π΄ ΡΠΎΠ²Π°
ΠΈΠ·ΠΏΡΠ»Π½Π΅Π½ΠΈΠ΅ Π½Π° ΠΊΠΎΠ΄. ΠΠΏΡΠ΅Π΄Π΅Π»Π΅Π½ Π°Π΄ΡΠ΅Ρ 1xB0 ΡΠ΅ Π·Π°ΡΠ΅ΠΆΠ΄Π° Π² R130, ΠΎΡ Π½Π΅Π³ΠΎ ΡΠ΅ ΠΈΠ·Π²Π°ΠΆΠ΄Π° 5, ΡΠ»Π΅Π΄ ΠΊΠΎΠ΅ΡΠΎ ΡΠ΅ ΠΏΡΠ΅Ρ
Π²ΡΡΠ»Ρ ΠΊΡΠΌ R0 ΠΈ ΠΊΡΠΌ Π½Π΅Π³ΠΎ ΡΠ΅ Π΄ΠΎΠ±Π°Π²Ρ 0x10. ΠΠΊΠ°Π·Π²Π° ΡΠ΅ 0xB13B. ΠΠΎ ΡΠΎΠ·ΠΈ Π½Π°ΡΠΈΠ½ IDA ΡΠΌΡΡΠ°, ΡΠ΅ ΠΏΠΎΡΠ»Π΅Π΄Π½Π°ΡΠ° ΠΈΠ½ΡΡΡΡΠΊΡΠΈΡ Π΅ Π½ΠΎΡΠΌΠ°Π»Π½ΠΎ Π²ΡΡΡΠ°Π½Π΅ Π½Π° ΡΡΠ½ΠΊΡΠΈΡ, Π½ΠΎ Π²ΡΡΡΠ½ΠΎΡΡ ΡΡ ΡΠΊΠ°ΡΠ° Π΄ΠΎ ΠΈΠ·ΡΠΈΡΠ»Π΅Π½ΠΈΡ Π°Π΄ΡΠ΅Ρ 0xB13B.
Π’ΡΠΊ ΡΠΈ ΡΡΡΡΠ²Π° Π΄Π° ΠΏΡΠΈΠΏΠΎΠΌΠ½ΠΈΠΌ, ΡΠ΅ ARM ΠΏΡΠΎΡΠ΅ΡΠΎΡΠΈΡΠ΅ ΠΈΠΌΠ°Ρ Π΄Π²Π° ΡΠ΅ΠΆΠΈΠΌΠ° ΠΈ Π΄Π²Π° Π½Π°Π±ΠΎΡΠ° ΠΈΠ½ΡΡΡΡΠΊΡΠΈΠΈ: ARM ΠΈ Thumb. ΠΠ°ΠΉ-ΠΌΠ°Π»ΠΊΠΈΡΡ Π±ΠΈΡ ΠΎΡ Π°Π΄ΡΠ΅ΡΠ° ΠΊΠ°Π·Π²Π° Π½Π° ΠΏΡΠΎΡΠ΅ΡΠΎΡΠ° ΠΊΠΎΠΉ Π½Π°Π±ΠΎΡ ΠΎΡ ΠΈΠ½ΡΡΡΡΠΊΡΠΈΠΈ ΡΠ΅ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°. Π’ΠΎΠ΅ΡΡ Π°Π΄ΡΠ΅ΡΡΡ Π²ΡΡΡΠ½ΠΎΡΡ Π΅ 0xB13A, Π° Π΅Π΄ΠΈΠ½ Π² Π½Π°ΠΉ-ΠΌΠ»Π°Π΄ΡΠΈΡΡ Π±ΠΈΡ ΠΏΠΎΠΊΠ°Π·Π²Π° ΡΠ΅ΠΆΠΈΠΌΠ° Thumb.
ΠΠΎΠ΄ΠΎΠ±Π΅Π½ βΠ°Π΄Π°ΠΏΡΠ΅Ρβ Π΅ Π΄ΠΎΠ±Π°Π²Π΅Π½ Π² Π½Π°ΡΠ°Π»ΠΎΡΠΎ Π½Π° Π²ΡΡΠΊΠ° ΡΡΠ½ΠΊΡΠΈΡ Π² ΡΠ°Π·ΠΈ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° ΠΈ
ΠΊΠΎΠ΄ Π·Π° Π±ΠΎΠΊΠ»ΡΠΊ. ΠΠΎ-Π½Π°ΡΠ°ΡΡΠΊ Π½ΡΠΌΠ° Π΄Π° ΡΠ΅ ΡΠΏΠΈΡΠ°ΠΌΠ΅ Π½Π° ΡΡΡ
ΠΏΠΎΠ΄ΡΠΎΠ±Π½ΠΎ - ΠΏΡΠΎΡΡΠΎ ΡΠΈ ΡΠΏΠΎΠΌΠ½ΡΠΌΠ΅
ΡΠ΅ ΠΈΡΡΠΈΠ½ΡΠΊΠΎΡΠΎ Π½Π°ΡΠ°Π»ΠΎ Π½Π° ΠΏΠΎΡΡΠΈ Π²ΡΠΈΡΠΊΠΈ ΡΡΠ½ΠΊΡΠΈΠΈ Π΅ ΠΌΠ°Π»ΠΊΠΎ ΠΏΠΎ-Π΄Π°Π»Π΅ΡΠ΅.
Π’ΡΠΉ ΠΊΠ°ΡΠΎ ΠΊΠΎΠ΄ΡΡ Π½Π΅ ΠΏΡΠ΅ΡΠΊΠ°ΡΠ° ΠΈΠ·ΡΠΈΡΠ½ΠΎ Π΄ΠΎ 0xB13A, ΡΠ°ΠΌΠ°ΡΠ° IDA Π½Π΅ ΡΠ°Π·ΠΏΠΎΠ·Π½Π°, ΡΠ΅ ΠΊΠΎΠ΄ΡΡ ΡΠ΅ Π½Π°ΠΌΠΈΡΠ° Π½Π° ΡΠΎΠ²Π° ΠΌΡΡΡΠΎ. ΠΠΎ ΡΡΡΠ°ΡΠ° ΠΏΡΠΈΡΠΈΠ½Π° ΡΠΎΠΉ Π½Π΅ ΡΠ°Π·ΠΏΠΎΠ·Π½Π°Π²Π° ΠΏΠΎ-Π³ΠΎΠ»ΡΠΌΠ°ΡΠ° ΡΠ°ΡΡ ΠΎΡ ΠΊΠΎΠ΄Π° Π² Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°ΡΠ° ΠΊΠ°ΡΠΎ ΠΊΠΎΠ΄, ΠΊΠΎΠ΅ΡΠΎ ΠΏΡΠ°Π²ΠΈ Π°Π½Π°Π»ΠΈΠ·Π° Π΄ΠΎΠ½ΡΠΊΡΠ΄Π΅ ΡΡΡΠ΄Π΅Π½. ΠΠ°Π·Π²Π°ΠΌΠ΅ Π½Π° IDA, ΡΠ΅ ΡΠΎΠ²Π° Π΅ ΠΊΠΎΠ΄ΡΡ, ΠΈ Π΅ΡΠΎ ΠΊΠ°ΠΊΠ²ΠΎ ΡΠ΅ ΡΠ»ΡΡΠ²Π°:
Π’Π°Π±Π»ΠΈΡΠ°ΡΠ° ΠΎΡΠ΅Π²ΠΈΠ΄Π½ΠΎ Π·Π°ΠΏΠΎΡΠ²Π° ΠΎΡ 0xB144. ΠΠ°ΠΊΠ²ΠΎ ΠΈΠΌΠ° Π² sub_494C?
ΠΠΎΠ³Π°ΡΠΎ ΠΈΠ·Π²ΠΈΠΊΠ²Π°ΠΌΠ΅ ΡΠ°Π·ΠΈ ΡΡΠ½ΠΊΡΠΈΡ Π² ΡΠ΅Π³ΠΈΡΡΡΡΠ° LR, ΠΏΠΎΠ»ΡΡΠ°Π²Π°ΠΌΠ΅ Π°Π΄ΡΠ΅ΡΠ° Π½Π° ΡΠΏΠΎΠΌΠ΅Π½Π°ΡΠ°ΡΠ° ΠΏΠΎ-Π³ΠΎΡΠ΅ ΡΠ°Π±Π»ΠΈΡΠ° (0xB144). Π R0 - ΠΈΠ½Π΄Π΅ΠΊΡ Π² ΡΠ°Π·ΠΈ ΡΠ°Π±Π»ΠΈΡΠ°. Π’ΠΎΠ΅ΡΡ ΡΡΠΎΠΉΠ½ΠΎΡΡΡΠ° ΡΠ΅ Π²Π·Π΅ΠΌΠ° ΠΎΡ ΡΠ°Π±Π»ΠΈΡΠ°ΡΠ°, Π΄ΠΎΠ±Π°Π²Ρ ΡΠ΅ ΠΊΡΠΌ LR ΠΈ ΡΠ΅Π·ΡΠ»ΡΠ°ΡΡΡ Π΅
Π°Π΄ΡΠ΅ΡΠ°, Π½Π° ΠΊΠΎΠΉΡΠΎ Π΄Π° ΠΎΡΠΈΠ΄Π΅ΡΠ΅. ΠΠ΅ΠΊΠ° ΡΠ΅ ΠΎΠΏΠΈΡΠ°ΠΌΠ΅ Π΄Π° Π³ΠΎ ΠΈΠ·ΡΠΈΡΠ»ΠΈΠΌ: 0xB144 + [0xB144 + 8* 4] = 0xB144 + 0x120 = 0xB264. ΠΡΠΈΠ²Π°ΠΌΠ΅ Π½Π° ΠΏΠΎΠ»ΡΡΠ΅Π½ΠΈΡ Π°Π΄ΡΠ΅Ρ ΠΈ Π²ΠΈΠΆΠ΄Π°ΠΌΠ΅ Π±ΡΠΊΠ²Π°Π»Π½ΠΎ Π½ΡΠΊΠΎΠ»ΠΊΠΎ ΠΏΠΎΠ»Π΅Π·Π½ΠΈ ΠΈΠ½ΡΡΡΡΠΊΡΠΈΠΈ ΠΈ ΠΎΡΠ½ΠΎΠ²ΠΎ ΠΎΡΠΈΠ²Π°ΠΌΠ΅ Π½Π° 0xB140:
Π‘Π΅Π³Π° ΡΠ΅ ΠΈΠΌΠ° ΠΏΡΠ΅Ρ
ΠΎΠ΄ ΠΏΡΠΈ ΠΎΡΠΌΠ΅ΡΡΠ²Π°Π½Π΅ Ρ ΠΈΠ½Π΄Π΅ΠΊΡ 0x20 ΠΎΡ ΡΠ°Π±Π»ΠΈΡΠ°ΡΠ°.
Π‘ΡΠ΄Π΅ΠΉΠΊΠΈ ΠΏΠΎ ΡΠ°Π·ΠΌΠ΅ΡΠ° Π½Π° ΡΠ°Π±Π»ΠΈΡΠ°ΡΠ°, ΡΠ΅ ΠΈΠΌΠ° ΠΌΠ½ΠΎΠ³ΠΎ ΡΠ°ΠΊΠΈΠ²Π° ΠΏΡΠ΅Ρ ΠΎΠ΄ΠΈ Π² ΠΊΠΎΠ΄Π°. ΠΡΠ·Π½ΠΈΠΊΠ²Π° Π²ΡΠΏΡΠΎΡΡΡ Π΄Π°Π»ΠΈ Π΅ Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎ ΠΏΠΎ Π½ΡΠΊΠ°ΠΊΡΠ² Π½Π°ΡΠΈΠ½ Π΄Π° ΡΠ΅ ΡΠΏΡΠ°Π²ΠΈΠΌ Ρ ΡΠΎΠ²Π° ΠΏΠΎ-Π°Π²ΡΠΎΠΌΠ°ΡΠΈΡΠ½ΠΎ, Π±Π΅Π· ΡΡΡΠ½ΠΎ ΠΈΠ·ΡΠΈΡΠ»ΡΠ²Π°Π½Π΅ Π½Π° Π°Π΄ΡΠ΅ΡΠΈ. Π ΡΠΊΡΠΈΠΏΡΠΎΠ²Π΅ΡΠ΅ ΠΈ Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡΡΠ° Π·Π° ΠΊΠΎΡΠ΅ΠΊΡΠΈΡ Π½Π° ΠΊΠΎΠ΄ Π² IDA Π½ΠΈ ΠΈΠ΄Π²Π°Ρ Π½Π° ΠΏΠΎΠΌΠΎΡ:
def put_unconditional_branch(source, destination):
offset = (destination - source - 4) >> 1
if offset > 2097151 or offset < -2097152:
raise RuntimeError("Invalid offset")
if offset > 1023 or offset < -1024:
instruction1 = 0xf000 | ((offset >> 11) & 0x7ff)
instruction2 = 0xb800 | (offset & 0x7ff)
patch_word(source, instruction1)
patch_word(source + 2, instruction2)
else:
instruction = 0xe000 | (offset & 0x7ff)
patch_word(source, instruction)
ea = here()
if get_wide_word(ea) == 0xb503: #PUSH {R0,R1,LR}
ea1 = ea + 2
if get_wide_word(ea1) == 0xbf00: #NOP
ea1 += 2
if get_operand_type(ea1, 0) == 1 and get_operand_value(ea1, 0) == 0 and get_operand_type(ea1, 1) == 2:
index = get_wide_dword(get_operand_value(ea1, 1))
print "index =", hex(index)
ea1 += 2
if get_operand_type(ea1, 0) == 7:
table = get_operand_value(ea1, 0) + 4
elif get_operand_type(ea1, 1) == 2:
table = get_operand_value(ea1, 1) + 4
else:
print "Wrong operand type on", hex(ea1), "-", get_operand_type(ea1, 0), get_operand_type(ea1, 1)
table = None
if table is None:
print "Unable to find table"
else:
print "table =", hex(table)
offset = get_wide_dword(table + (index << 2))
put_unconditional_branch(ea, table + offset)
else:
print "Unknown code", get_operand_type(ea1, 0), get_operand_value(ea1, 0), get_operand_type(ea1, 1) == 2
else:
print "Unable to detect first instruction"
ΠΠΎΡΡΠ°Π²Π΅ΡΠ΅ ΠΊΡΡΡΠΎΡΠ° Π½Π° ΡΠ΅Π΄ 0xB26A, ΡΡΠ°ΡΡΠΈΡΠ°ΠΉΡΠ΅ ΡΠΊΡΠΈΠΏΡΠ° ΠΈ Π²ΠΈΠΆΡΠ΅ ΠΏΡΠ΅Ρ ΠΎΠ΄Π° ΠΊΡΠΌ 0xB4B0:
IDA ΠΎΡΠ½ΠΎΠ²ΠΎ Π½Π΅ ΡΠ°Π·ΠΏΠΎΠ·Π½Π° ΡΠ°Π·ΠΈ ΠΎΠ±Π»Π°ΡΡ ΠΊΠ°ΡΠΎ ΠΊΠΎΠ΄. ΠΠΈΠ΅ ΠΉ ΠΏΠΎΠΌΠ°Π³Π°ΠΌΠ΅ ΠΈ Π²ΠΈΠΆΠ΄Π°ΠΌΠ΅ Π΄ΡΡΠ³ Π΄ΠΈΠ·Π°ΠΉΠ½ ΡΠ°ΠΌ:
ΠΠ½ΡΡΡΡΠΊΡΠΈΠΈΡΠ΅ ΡΠ»Π΅Π΄ BLX ΠΌΠ°ΠΉ Π½ΡΠΌΠ°Ρ ΠΎΡΠΎΠ±Π΅Π½ ΡΠΌΠΈΡΡΠ», ΠΏΠΎ-ΡΠΊΠΎΡΠΎ Π΅ Π½ΡΠΊΠ°ΠΊΠ²ΠΎ ΠΈΠ·ΠΌΠ΅ΡΡΠ²Π°Π½Π΅. ΠΠ΅ΠΊΠ° Π΄Π° ΡΠ°Π·Π³Π»Π΅Π΄Π°ΠΌΠ΅ sub_4964:
Π Π½Π°ΠΈΡΡΠΈΠ½Π°, ΡΡΠΊ ΡΠ΅ Π²Π·Π΅ΠΌΠ° dword Π½Π° Π°Π΄ΡΠ΅ΡΠ°, ΠΊΠΎΠΉΡΠΎ ΡΠ΅ Π½Π°ΠΌΠΈΡΠ° Π² LR, Π΄ΠΎΠ±Π°Π²Ρ ΡΠ΅ ΠΊΡΠΌ ΡΠΎΠ·ΠΈ Π°Π΄ΡΠ΅Ρ, ΡΠ»Π΅Π΄ ΠΊΠΎΠ΅ΡΠΎ ΡΡΠΎΠΉΠ½ΠΎΡΡΡΠ° Π½Π° ΠΏΠΎΠ»ΡΡΠ΅Π½ΠΈΡ Π°Π΄ΡΠ΅Ρ ΡΠ΅ Π²Π·Π΅ΠΌΠ° ΠΈ ΡΠ΅ ΠΏΠΎΡΡΠ°Π²Ρ Π² ΡΡΠ΅ΠΊΠ°. Π‘ΡΡΠΎ ΡΠ°ΠΊΠ°, 4 ΡΠ΅ Π΄ΠΎΠ±Π°Π²Ρ ΠΊΡΠΌ LR, ΡΠ°ΠΊΠ° ΡΠ΅ ΡΠ»Π΅Π΄ Π²ΡΡΡΠ°Π½Π΅ ΠΎΡ ΡΡΠ½ΠΊΡΠΈΡΡΠ° ΡΡΡΠΎΡΠΎ ΠΎΡΠΌΠ΅ΡΡΠ²Π°Π½Π΅ ΡΠ΅ ΠΏΡΠΎΠΏΡΡΠΊΠ°. Π‘Π»Π΅Π΄ ΠΊΠΎΠ΅ΡΠΎ ΠΊΠΎΠΌΠ°Π½Π΄Π°ΡΠ° POP {R1} Π²Π·Π΅ΠΌΠ° ΠΏΠΎΠ»ΡΡΠ΅Π½Π°ΡΠ° ΡΡΠΎΠΉΠ½ΠΎΡΡ ΠΎΡ ΡΡΠ΅ΠΊΠ°. ΠΠΊΠΎ ΠΏΠΎΠ³Π»Π΅Π΄Π½Π΅ΡΠ΅ ΠΊΠ°ΠΊΠ²ΠΎ ΡΠ΅ Π½Π°ΠΌΠΈΡΠ° Π½Π° Π°Π΄ΡΠ΅Ρ 0xB4BA + 0xEA = 0xB5A4, ΡΠ΅ Π²ΠΈΠ΄ΠΈΡΠ΅ Π½Π΅ΡΠΎ ΠΏΠΎΠ΄ΠΎΠ±Π½ΠΎ Π½Π° Π°Π΄ΡΠ΅ΡΠ½Π° ΡΠ°Π±Π»ΠΈΡΠ°:
ΠΠ° Π΄Π° ΠΊΠΎΡΠΈΠ³ΠΈΡΠ°ΡΠ΅ ΡΠΎΠ·ΠΈ Π΄ΠΈΠ·Π°ΠΉΠ½, ΡΠ΅ ΡΡΡΠ±Π²Π° Π΄Π° ΠΏΠΎΠ»ΡΡΠΈΡΠ΅ Π΄Π²Π° ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΡΠ° ΠΎΡ ΠΊΠΎΠ΄Π°: ΠΎΡΠΌΠ΅ΡΡΠ²Π°Π½Π΅ΡΠΎ ΠΈ Π½ΠΎΠΌΠ΅ΡΠ° Π½Π° ΡΠ΅Π³ΠΈΡΡΡΡΠ°, Π² ΠΊΠΎΠΉΡΠΎ ΠΈΡΠΊΠ°ΡΠ΅ Π΄Π° ΠΏΠΎΡΡΠ°Π²ΠΈΡΠ΅ ΡΠ΅Π·ΡΠ»ΡΠ°ΡΠ°. ΠΠ° Π²ΡΠ΅ΠΊΠΈ Π²ΡΠ·ΠΌΠΎΠΆΠ΅Π½ ΡΠ΅Π³ΠΈΡΡΡΡ ΡΠ΅ ΡΡΡΠ±Π²Π° ΠΏΡΠ΅Π΄Π²Π°ΡΠΈΡΠ΅Π»Π½ΠΎ Π΄Π° ΠΏΠΎΠ΄Π³ΠΎΡΠ²ΠΈΡΠ΅ ΡΠ°ΡΡ ΠΎΡ ΠΊΠΎΠ΄Π°.
patches = {}
patches[0] = (0x00, 0xbf, 0x01, 0x48, 0x00, 0x68, 0x02, 0xe0)
patches[1] = (0x00, 0xbf, 0x01, 0x49, 0x09, 0x68, 0x02, 0xe0)
patches[2] = (0x00, 0xbf, 0x01, 0x4a, 0x12, 0x68, 0x02, 0xe0)
patches[3] = (0x00, 0xbf, 0x01, 0x4b, 0x1b, 0x68, 0x02, 0xe0)
patches[4] = (0x00, 0xbf, 0x01, 0x4c, 0x24, 0x68, 0x02, 0xe0)
patches[5] = (0x00, 0xbf, 0x01, 0x4d, 0x2d, 0x68, 0x02, 0xe0)
patches[8] = (0x00, 0xbf, 0xdf, 0xf8, 0x06, 0x80, 0xd8, 0xf8, 0x00, 0x80, 0x01, 0xe0)
patches[9] = (0x00, 0xbf, 0xdf, 0xf8, 0x06, 0x90, 0xd9, 0xf8, 0x00, 0x90, 0x01, 0xe0)
patches[10] = (0x00, 0xbf, 0xdf, 0xf8, 0x06, 0xa0, 0xda, 0xf8, 0x00, 0xa0, 0x01, 0xe0)
patches[11] = (0x00, 0xbf, 0xdf, 0xf8, 0x06, 0xb0, 0xdb, 0xf8, 0x00, 0xb0, 0x01, 0xe0)
ea = here()
if (get_wide_word(ea) == 0xb082 #SUB SP, SP, #8
and get_wide_word(ea + 2) == 0xb503): #PUSH {R0,R1,LR}
if get_operand_type(ea + 4, 0) == 7:
pop = get_bytes(ea + 12, 4, 0)
if pop[1] == 'xbc':
register = -1
r = get_wide_byte(ea + 12)
for i in range(8):
if r == (1 << i):
register = i
break
if register == -1:
print "Unable to detect register"
else:
address = get_wide_dword(ea + 8) + ea + 8
for b in patches[register]:
patch_byte(ea, b)
ea += 1
if ea % 4 != 0:
ea += 2
patch_dword(ea, address)
elif pop[:3] == 'x5dxf8x04':
register = ord(pop[3]) >> 4
if register in patches:
address = get_wide_dword(ea + 8) + ea + 8
for b in patches[register]:
patch_byte(ea, b)
ea += 1
patch_dword(ea, address)
else:
print "POP instruction not found"
else:
print "Wrong operand type on +4:", get_operand_type(ea + 4, 0)
else:
print "Unable to detect first instructions"
ΠΠΎΡΡΠ°Π²ΡΠΌΠ΅ ΠΊΡΡΡΠΎΡΠ° Π² Π½Π°ΡΠ°Π»ΠΎΡΠΎ Π½Π° ΡΡΡΡΠΊΡΡΡΠ°ΡΠ°, ΠΊΠΎΡΡΠΎ ΠΈΡΠΊΠ°ΠΌΠ΅ Π΄Π° Π·Π°ΠΌΠ΅Π½ΠΈΠΌ - 0xB4B2 - ΠΈ ΡΡΠ°ΡΡΠΈΡΠ°ΠΌΠ΅ ΡΠΊΡΠΈΠΏΡΠ°:
Π Π΄ΠΎΠΏΡΠ»Π½Π΅Π½ΠΈΠ΅ ΠΊΡΠΌ Π²Π΅ΡΠ΅ ΡΠΏΠΎΠΌΠ΅Π½Π°ΡΠΈΡΠ΅ ΡΡΡΡΠΊΡΡΡΠΈ, ΠΊΠΎΠ΄ΡΡ ΡΡΠ΄ΡΡΠΆΠ° ΠΈ ΡΠ»Π΅Π΄Π½ΠΎΡΠΎ:
ΠΠ°ΠΊΡΠΎ Π² ΠΏΡΠ΅Π΄ΠΈΡΠ½ΠΈΡ ΡΠ»ΡΡΠ°ΠΉ, ΡΠ»Π΅Π΄ ΠΈΠ½ΡΡΡΡΠΊΡΠΈΡΡΠ° BLX ΠΈΠΌΠ° ΠΎΡΠΌΠ΅ΡΡΠ²Π°Π½Π΅:
ΠΠ·ΠΈΠΌΠ°ΠΌΠ΅ ΠΎΡΠΌΠ΅ΡΡΠ²Π°Π½Π΅ΡΠΎ ΠΊΡΠΌ Π°Π΄ΡΠ΅ΡΠ° ΠΎΡ LR, Π΄ΠΎΠ±Π°Π²ΡΠΌΠ΅ Π³ΠΎ ΠΊΡΠΌ LR ΠΈ ΠΎΡΠΈΠ²Π°ΠΌΠ΅ ΡΠ°ΠΌ. 0x72044 + 0xC = 0x72050. Π‘ΠΊΡΠΈΠΏΡΡΡ Π·Π° ΡΠΎΠ·ΠΈ Π΄ΠΈΠ·Π°ΠΉΠ½ Π΅ Π΄ΠΎΡΡΠ° ΠΏΡΠΎΡΡ:
def put_unconditional_branch(source, destination):
offset = (destination - source - 4) >> 1
if offset > 2097151 or offset < -2097152:
raise RuntimeError("Invalid offset")
if offset > 1023 or offset < -1024:
instruction1 = 0xf000 | ((offset >> 11) & 0x7ff)
instruction2 = 0xb800 | (offset & 0x7ff)
patch_word(source, instruction1)
patch_word(source + 2, instruction2)
else:
instruction = 0xe000 | (offset & 0x7ff)
patch_word(source, instruction)
ea = here()
if get_wide_word(ea) == 0xb503: #PUSH {R0,R1,LR}
ea1 = ea + 6
if get_wide_word(ea + 2) == 0xbf00: #NOP
ea1 += 2
offset = get_wide_dword(ea1)
put_unconditional_branch(ea, (ea1 + offset) & 0xffffffff)
else:
print "Unable to detect first instruction"
Π Π΅Π·ΡΠ»ΡΠ°Ρ ΠΎΡ ΠΈΠ·ΠΏΡΠ»Π½Π΅Π½ΠΈΠ΅ΡΠΎ Π½Π° ΡΠΊΡΠΈΠΏΡΠ°:
Π‘Π»Π΅Π΄ ΠΊΠ°ΡΠΎ Π²ΡΠΈΡΠΊΠΎ Π΅ Π·Π°ΠΊΡΡΠΏΠ΅Π½ΠΎ Π²ΡΠ² ΡΡΠ½ΠΊΡΠΈΡΡΠ°, ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° ΠΏΠΎΡΠΎΡΠΈΡΠ΅ IDA ΠΊΡΠΌ Π½Π΅ΠΉΠ½ΠΎΡΠΎ ΠΈΡΡΠΈΠ½ΡΠΊΠΎ Π½Π°ΡΠ°Π»ΠΎ. Π’ΠΎΠΉ ΡΠ΅ ΡΠ³Π»ΠΎΠ±ΠΈ ΡΠ΅Π»ΠΈΡ ΡΡΠ½ΠΊΡΠΈΠΎΠ½Π°Π»Π΅Π½ ΠΊΠΎΠ΄ ΠΈ ΠΌΠΎΠΆΠ΅ Π΄Π° Π±ΡΠ΄Π΅ Π΄Π΅ΠΊΠΎΠΌΠΏΠΈΠ»ΠΈΡΠ°Π½ Ρ ΠΏΠΎΠΌΠΎΡΡΠ° Π½Π° HexRays.
ΠΠ΅ΠΊΠΎΠ΄ΠΈΡΠ°Π½Π΅ Π½Π° Π½ΠΈΠ·ΠΎΠ²Π΅
ΠΠ°ΡΡΠΈΡ ΠΌΠ΅ ΡΠ΅ Π΄Π° ΡΠ΅ ΡΠΏΡΠ°Π²ΡΠΌΠ΅ Ρ ΠΎΠ±ΡΡΡΠΊΠ°ΡΠΈΡΡΠ° Π½Π° ΠΌΠ°ΡΠΈΠ½Π½ΠΈΡ ΠΊΠΎΠ΄ Π² Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°ΡΠ° libsgmainso-6.4.36.so ΠΎΡ UC Browser ΠΈ ΠΏΠΎΠ»ΡΡΠΈ ΡΡΠ½ΠΊΡΠΈΠΎΠ½Π°Π»Π½ΠΈΡ ΠΊΠΎΠ΄ JNI_OnLoad.
int __fastcall real_JNI_OnLoad(JavaVM *vm)
{
int result; // r0
jclass clazz; // r0 MAPDST
int v4; // r0
JNIEnv *env; // r4
int v6; // [sp-40h] [bp-5Ch]
int v7; // [sp+Ch] [bp-10h]
v7 = *(_DWORD *)off_8AC00;
if ( !vm )
goto LABEL_39;
sub_7C4F4();
env = (JNIEnv *)sub_7C5B0(0);
if ( !env )
goto LABEL_39;
v4 = sub_72CCC();
sub_73634(v4);
sub_73E24(&unk_83EA6, &v6, 49);
clazz = (jclass)((int (__fastcall *)(JNIEnv *, int *))(*env)->FindClass)(env, &v6);
if ( clazz
&& (sub_9EE4(),
sub_71D68(env),
sub_E7DC(env) >= 0
&& sub_69D68(env) >= 0
&& sub_197B4(env, clazz) >= 0
&& sub_E240(env, clazz) >= 0
&& sub_B8B0(env, clazz) >= 0
&& sub_5F0F4(env, clazz) >= 0
&& sub_70640(env, clazz) >= 0
&& sub_11F3C(env) >= 0
&& sub_21C3C(env, clazz) >= 0
&& sub_2148C(env, clazz) >= 0
&& sub_210E0(env, clazz) >= 0
&& sub_41B58(env, clazz) >= 0
&& sub_27920(env, clazz) >= 0
&& sub_293E8(env, clazz) >= 0
&& sub_208F4(env, clazz) >= 0) )
{
result = (sub_B7B0(env, clazz) >> 31) | 0x10004;
}
else
{
LABEL_39:
result = -1;
}
return result;
}
ΠΠ΅ΠΊΠ° ΡΠ°Π·Π³Π»Π΅Π΄Π°ΠΌΠ΅ ΠΏΠΎ-ΠΏΠΎΠ΄ΡΠΎΠ±Π½ΠΎ ΡΠ»Π΅Π΄Π½ΠΈΡΠ΅ ΡΠ΅Π΄ΠΎΠ²Π΅:
sub_73E24(&unk_83EA6, &v6, 49);
clazz = (jclass)((int (__fastcall *)(JNIEnv *, int *))(*env)->FindClass)(env, &v6);
ΠΡΠ² ΡΡΠ½ΠΊΡΠΈΡ sub_73E24 ΠΈΠΌΠ΅ΡΠΎ Π½Π° ΠΊΠ»Π°ΡΠ° ΠΎΡΠ΅Π²ΠΈΠ΄Π½ΠΎ ΡΠ΅ Π΄Π΅ΡΠΈΡΡΠΈΡΠ°. ΠΠ°ΡΠΎ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ Π½Π° ΡΠ°Π·ΠΈ ΡΡΠ½ΠΊΡΠΈΡ ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π° ΡΠΊΠ°Π·Π°ΡΠ΅Π» ΠΊΡΠΌ Π΄Π°Π½Π½ΠΈ, ΠΏΠΎΠ΄ΠΎΠ±Π½ΠΈ Π½Π° ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½ΠΈ Π΄Π°Π½Π½ΠΈ, ΠΎΠΏΡΠ΅Π΄Π΅Π»Π΅Π½ Π±ΡΡΠ΅Ρ ΠΈ ΡΠΈΡΠ»ΠΎ. ΠΡΠ΅Π²ΠΈΠ΄Π½ΠΎ ΡΠ»Π΅Π΄ ΠΈΠ·Π²ΠΈΠΊΠ²Π°Π½Π΅ΡΠΎ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° ΡΠ΅ ΠΈΠΌΠ° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½ ΡΠ΅Π΄ Π² Π±ΡΡΠ΅ΡΠ°, ΡΡΠΉ ΠΊΠ°ΡΠΎ ΡΠΎΠΉ ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π° Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° FindClass, ΠΊΠΎΠΉΡΠΎ ΠΏΡΠΈΠ΅ΠΌΠ° ΠΈΠΌΠ΅ΡΠΎ Π½Π° ΠΊΠ»Π°ΡΠ° ΠΊΠ°ΡΠΎ Π²ΡΠΎΡΠΈ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΡ. Π‘Π»Π΅Π΄ΠΎΠ²Π°ΡΠ΅Π»Π½ΠΎ ΡΠΈΡΠ»ΠΎΡΠΎ Π΅ ΡΠ°Π·ΠΌΠ΅ΡΡΡ Π½Π° Π±ΡΡΠ΅ΡΠ° ΠΈΠ»ΠΈ Π΄ΡΠ»ΠΆΠΈΠ½Π°ΡΠ° Π½Π° Π»ΠΈΠ½ΠΈΡΡΠ°. ΠΠ΅ΠΊΠ° ΡΠ΅ ΠΎΠΏΠΈΡΠ°ΠΌΠ΅ Π΄Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°ΠΌΠ΅ ΠΈΠΌΠ΅ΡΠΎ Π½Π° ΠΊΠ»Π°ΡΠ°, ΡΠΎ ΡΡΡΠ±Π²Π° Π΄Π° Π½ΠΈ ΠΊΠ°ΠΆΠ΅ Π΄Π°Π»ΠΈ Π²ΡΡΠ²ΠΈΠΌ Π² ΠΏΡΠ°Π²ΠΈΠ»Π½Π°ΡΠ° ΠΏΠΎΡΠΎΠΊΠ°. ΠΠ΅ΠΊΠ° Π΄Π° ΡΠ°Π·Π³Π»Π΅Π΄Π°ΠΌΠ΅ ΠΏΠΎ-ΠΎΡΠ±Π»ΠΈΠ·ΠΎ ΠΊΠ°ΠΊΠ²ΠΎ ΡΠ΅ ΡΠ»ΡΡΠ²Π° Π² sub_73E24.
int __fastcall sub_73E56(unsigned __int8 *in, unsigned __int8 *out, size_t size)
{
int v4; // r6
int v7; // r11
int v8; // r9
int v9; // r4
size_t v10; // r5
int v11; // r0
struc_1 v13; // [sp+0h] [bp-30h]
int v14; // [sp+1Ch] [bp-14h]
int v15; // [sp+20h] [bp-10h]
v4 = 0;
v15 = *(_DWORD *)off_8AC00;
v14 = 0;
v7 = sub_7AF78(17);
v8 = sub_7AF78(size);
if ( !v7 )
{
v9 = 0;
goto LABEL_12;
}
(*(void (__fastcall **)(int, const char *, int))(v7 + 12))(v7, "DcO/lcK+h?m3c*q@", 16);
if ( !v8 )
{
LABEL_9:
v4 = 0;
goto LABEL_10;
}
v4 = 0;
if ( !in )
{
LABEL_10:
v9 = 0;
goto LABEL_11;
}
v9 = 0;
if ( out )
{
memset(out, 0, size);
v10 = size - 1;
(*(void (__fastcall **)(int, unsigned __int8 *, size_t))(v8 + 12))(v8, in, v10);
memset(&v13, 0, 0x14u);
v13.field_4 = 3;
v13.field_10 = v7;
v13.field_14 = v8;
v11 = sub_6115C(&v13, &v14);
v9 = v11;
if ( v11 )
{
if ( *(_DWORD *)(v11 + 4) == v10 )
{
qmemcpy(out, *(const void **)v11, v10);
v4 = *(_DWORD *)(v9 + 4);
}
else
{
v4 = 0;
}
goto LABEL_11;
}
goto LABEL_9;
}
LABEL_11:
sub_7B148(v7);
LABEL_12:
if ( v8 )
sub_7B148(v8);
if ( v9 )
sub_7B148(v9);
return v4;
}
Π€ΡΠ½ΠΊΡΠΈΡ sub_7AF78 ΡΡΠ·Π΄Π°Π²Π° Π΅ΠΊΠ·Π΅ΠΌΠΏΠ»ΡΡ Π½Π° ΠΊΠΎΠ½ΡΠ΅ΠΉΠ½Π΅Ρ Π·Π° Π±Π°ΠΉΡΠΎΠ²ΠΈ ΠΌΠ°ΡΠΈΠ²ΠΈ Ρ ΠΎΠΏΡΠ΅Π΄Π΅Π»Π΅Π½ ΡΠ°Π·ΠΌΠ΅Ρ (Π½ΡΠΌΠ° Π΄Π° ΡΠ΅ ΡΠΏΠΈΡΠ°ΠΌΠ΅ ΠΏΠΎΠ΄ΡΠΎΠ±Π½ΠΎ Π½Π° ΡΠ΅Π·ΠΈ ΠΊΠΎΠ½ΡΠ΅ΠΉΠ½Π΅ΡΠΈ). Π’ΡΠΊ ΡΠ΅ ΡΡΠ·Π΄Π°Π²Π°Ρ Π΄Π²Π° ΡΠ°ΠΊΠΈΠ²Π° ΠΊΠΎΠ½ΡΠ΅ΠΉΠ½Π΅ΡΠ°: Π΅Π΄ΠΈΠ½ΠΈΡΡ ΡΡΠ΄ΡΡΠΆΠ° Π»ΠΈΠ½ΠΈΡΡΠ° βDcO/lcK+h?m3c*q@β (Π»Π΅ΡΠ½ΠΎ Π΅ Π΄Π° ΡΠ΅ Π΄ΠΎΡΠ΅ΡΠΈΡΠ΅, ΡΠ΅ ΡΠΎΠ²Π° Π΅ ΠΊΠ»ΡΡ), Π΄ΡΡΠ³ΠΈΡΡ ΡΡΠ΄ΡΡΠΆΠ° ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½ΠΈ Π΄Π°Π½Π½ΠΈ. Π‘Π»Π΅Π΄ ΡΠΎΠ²Π° Π΄Π²Π°ΡΠ° ΠΎΠ±Π΅ΠΊΡΠ° ΡΠ΅ ΠΏΠΎΡΡΠ°Π²ΡΡ Π² ΠΎΠΏΡΠ΅Π΄Π΅Π»Π΅Π½Π° ΡΡΡΡΠΊΡΡΡΠ°, ΠΊΠΎΡΡΠΎ ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π° Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° sub_6115C. ΠΠ΅ΠΊΠ° ΡΡΡΠΎ Π΄Π° ΠΌΠ°ΡΠΊΠΈΡΠ°ΠΌΠ΅ ΠΏΠΎΠ»Π΅ ΡΡΡ ΡΡΠΎΠΉΠ½ΠΎΡΡ 3 Π² ΡΠ°Π·ΠΈ ΡΡΡΡΠΊΡΡΡΠ°.ΠΠ΅ΠΊΠ° Π²ΠΈΠ΄ΠΈΠΌ ΠΊΠ°ΠΊΠ²ΠΎ ΡΠ΅ ΡΠ΅ ΡΠ»ΡΡΠΈ Ρ ΡΠ°Π·ΠΈ ΡΡΡΡΠΊΡΡΡΠ° ΡΠ»Π΅Π΄ ΡΠΎΠ²Π°.
int __fastcall sub_611B4(struc_1 *a1, _DWORD *a2)
{
int v3; // lr
unsigned int v4; // r1
int v5; // r0
int v6; // r1
int result; // r0
int v8; // r0
*a2 = 820000;
if ( a1 )
{
v3 = a1->field_14;
if ( v3 )
{
v4 = a1->field_4;
if ( v4 < 0x19 )
{
switch ( v4 )
{
case 0u:
v8 = sub_6419C(a1->field_0, a1->field_10, v3);
goto LABEL_17;
case 3u:
v8 = sub_6364C(a1->field_0, a1->field_10, v3);
goto LABEL_17;
case 0x10u:
case 0x11u:
case 0x12u:
v8 = sub_612F4(
a1->field_0,
v4,
*(_QWORD *)&a1->field_8,
*(_QWORD *)&a1->field_8 >> 32,
a1->field_10,
v3,
a2);
goto LABEL_17;
case 0x14u:
v8 = sub_63A28(a1->field_0, v3);
goto LABEL_17;
case 0x15u:
sub_61A60(a1->field_0, v3, a2);
return result;
case 0x16u:
v8 = sub_62440(a1->field_14);
goto LABEL_17;
case 0x17u:
v8 = sub_6226C(a1->field_10, v3);
goto LABEL_17;
case 0x18u:
v8 = sub_63530(a1->field_14);
LABEL_17:
v6 = 0;
if ( v8 )
{
*a2 = 0;
v6 = v8;
}
return v6;
default:
LOWORD(v5) = 28032;
goto LABEL_5;
}
}
}
}
LOWORD(v5) = -27504;
LABEL_5:
HIWORD(v5) = 13;
v6 = 0;
*a2 = v5;
return v6;
}
ΠΠ°ΡΠ°ΠΌΠ΅ΡΡΡΡΡ Π·Π° ΠΏΡΠ΅Π²ΠΊΠ»ΡΡΠ²Π°Π½Π΅ Π΅ ΡΡΡΡΠΊΡΡΡΠ½ΠΎ ΠΏΠΎΠ»Π΅, Π½Π° ΠΊΠΎΠ΅ΡΠΎ ΠΏΡΠ΅Π΄ΠΈ ΡΠΎΠ²Π° Π΅ Π±ΠΈΠ»Π° ΠΏΡΠΈΡΠ²ΠΎΠ΅Π½Π° ΡΡΠΎΠΉΠ½ΠΎΡΡ 3. ΠΠΈΠΆΡΠ΅ ΡΠ»ΡΡΠ°ΠΉ 3: ΠΊΡΠΌ ΡΡΠ½ΠΊΡΠΈΡΡΠ° sub_6364C ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈΡΠ΅ ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π°Ρ ΠΎΡ ΡΡΡΡΠΊΡΡΡΠ°ΡΠ°, ΠΊΠΎΡΡΠΎ Π΅ Π΄ΠΎΠ±Π°Π²Π΅Π½Π° ΡΠ°ΠΌ Π² ΠΏΡΠ΅Π΄ΠΈΡΠ½Π°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ, Ρ.Π΅. ΠΊΠ»ΡΡΡΡ ΠΈ ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½ΠΈΡΠ΅ Π΄Π°Π½Π½ΠΈ. ΠΠΊΠΎ ΡΠ΅ Π²Π³Π»Π΅Π΄Π°ΡΠ΅ Π²Π½ΠΈΠΌΠ°ΡΠ΅Π»Π½ΠΎ Π² sub_6364C, ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° ΡΠ°Π·ΠΏΠΎΠ·Π½Π°Π΅ΡΠ΅ Π°Π»Π³ΠΎΡΠΈΡΡΠΌΠ° RC4 Π² Π½Π΅Π³ΠΎ.
ΠΠΌΠ°ΠΌΠ΅ Π°Π»Π³ΠΎΡΠΈΡΡΠΌ ΠΈ ΠΊΠ»ΡΡ. ΠΠ΅ΠΊΠ° ΡΠ΅ ΠΎΠΏΠΈΡΠ°ΠΌΠ΅ Π΄Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°ΠΌΠ΅ ΠΈΠΌΠ΅ΡΠΎ Π½Π° ΠΊΠ»Π°ΡΠ°. ΠΡΠΎ ΠΊΠ°ΠΊΠ²ΠΎ ΡΠ΅ ΡΠ»ΡΡΠΈ: com/taobao/wireless/security/adapter/JNICLibrary. Π‘ΡΡΠ°Ρ ΠΎΡΠ΅Π½! ΠΠΈΠ΅ ΡΠΌΠ΅ Π½Π° ΠΏΡΠ°Π² ΠΏΡΡ.
ΠΠΎΠΌΠ°Π½Π΄Π½ΠΎ Π΄ΡΡΠ²ΠΎ
Π‘Π΅Π³Π° ΡΡΡΠ±Π²Π° Π΄Π° Π½Π°ΠΌΠ΅ΡΠΈΠΌ ΠΏΡΠ΅Π΄ΠΈΠ·Π²ΠΈΠΊΠ°ΡΠ΅Π»ΡΡΠ²ΠΎ Π Π΅Π³ΠΈΡΡΡΠΈΡΠ°ΠΉΡΠ΅ ΡΠ΅, ΠΊΠΎΠ΅ΡΠΎ ΡΠ΅ Π½ΠΈ Π½Π°ΡΠΎΡΠΈ ΠΊΡΠΌ ΡΡΠ½ΠΊΡΠΈΡΡΠ° doCommandNative. ΠΠ΅ΠΊΠ° ΡΠ°Π·Π³Π»Π΅Π΄Π°ΠΌΠ΅ ΡΡΠ½ΠΊΡΠΈΠΈΡΠ΅, ΠΈΠ·Π²ΠΈΠΊΠ°Π½ΠΈ ΠΎΡ JNI_OnLoad, ΠΈ Π³ΠΎ Π½Π°ΠΌΠΈΡΠ°ΠΌΠ΅ Π² sub_B7B0:
int __fastcall sub_B7F6(JNIEnv *env, jclass clazz)
{
char signature[41]; // [sp+7h] [bp-55h]
char name[16]; // [sp+30h] [bp-2Ch]
JNINativeMethod method; // [sp+40h] [bp-1Ch]
int v8; // [sp+4Ch] [bp-10h]
v8 = *(_DWORD *)off_8AC00;
decryptString((unsigned __int8 *)&unk_83ED9, (unsigned __int8 *)name, 0x10u);// doCommandNative
decryptString((unsigned __int8 *)&unk_83EEA, (unsigned __int8 *)signature, 0x29u);// (I[Ljava/lang/Object;)Ljava/lang/Object;
method.name = name;
method.signature = signature;
method.fnPtr = sub_B69C;
return ((int (__fastcall *)(JNIEnv *, jclass, JNINativeMethod *, int))(*env)->RegisterNatives)(env, clazz, &method, 1) >> 31;
}
Π Π½Π°ΠΈΡΡΠΈΠ½Π° ΡΡΠΊ Π΅ ΡΠ΅Π³ΠΈΡΡΡΠΈΡΠ°Π½ Π΅ΡΡΠ΅ΡΡΠ²Π΅Π½ ΠΌΠ΅ΡΠΎΠ΄ Ρ ΠΈΠΌΠ΅ΡΠΎ doCommandNative. Π‘Π΅Π³Π° Π·Π½Π°Π΅ΠΌ Π°Π΄ΡΠ΅ΡΠ° ΠΌΡ. ΠΠ° Π²ΠΈΠ΄ΠΈΠΌ ΠΊΠ°ΠΊΠ²ΠΎ ΠΏΡΠ°Π²ΠΈ.
int __fastcall doCommandNative(JNIEnv *env, jobject obj, int command, jarray args)
{
int v5; // r5
struc_2 *a5; // r6
int v9; // r1
int v11; // [sp+Ch] [bp-14h]
int v12; // [sp+10h] [bp-10h]
v5 = 0;
v12 = *(_DWORD *)off_8AC00;
v11 = 0;
a5 = (struc_2 *)malloc(0x14u);
if ( a5 )
{
a5->field_0 = 0;
a5->field_4 = 0;
a5->field_8 = 0;
a5->field_C = 0;
v9 = command % 10000 / 100;
a5->field_0 = command / 10000;
a5->field_4 = v9;
a5->field_8 = command % 100;
a5->field_C = env;
a5->field_10 = args;
v5 = sub_9D60(command / 10000, v9, command % 100, 1, (int)a5, &v11);
}
free(a5);
if ( !v5 && v11 )
sub_7CF34(env, v11, &byte_83ED7);
return v5;
}
ΠΠΎ ΠΈΠΌΠ΅ΡΠΎ ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° ΠΏΠΎΠ·Π½Π°Π΅ΡΠ΅, ΡΠ΅ ΡΡΠΊ Π΅ Π²Ρ ΠΎΠ΄Π½Π°ΡΠ° ΡΠΎΡΠΊΠ° Π½Π° Π²ΡΠΈΡΠΊΠΈ ΡΡΠ½ΠΊΡΠΈΠΈ, ΠΊΠΎΠΈΡΠΎ ΡΠ°Π·ΡΠ°Π±ΠΎΡΡΠΈΡΠΈΡΠ΅ ΡΠ΅ΡΠΈΡ Π° Π΄Π° ΠΏΡΠ΅Ρ Π²ΡΡΠ»ΡΡ Π² ΡΠΎΠ΄Π½Π°ΡΠ° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°. ΠΠ½ΡΠ΅ΡΠ΅ΡΡΠ²Π°ΠΌΠ΅ ΡΠ΅ ΠΎΡ ΡΡΠ½ΠΊΡΠΈΡ Π½ΠΎΠΌΠ΅Ρ 10601.
ΠΠΎΠΆΠ΅ΡΠ΅ Π΄Π° Π²ΠΈΠ΄ΠΈΡΠ΅ ΠΎΡ ΠΊΠΎΠ΄Π°, ΡΠ΅ Π½ΠΎΠΌΠ΅ΡΡΡ Π½Π° ΠΊΠΎΠΌΠ°Π½Π΄Π°ΡΠ° ΠΏΡΠΎΠΈΠ·Π²Π΅ΠΆΠ΄Π° ΡΡΠΈ ΡΠΈΡΠ»Π°: ΠΊΠΎΠΌΠ°Π½Π΄Π°/10000, ΠΊΠΎΠΌΠ°Π½Π΄Π° % 10000 / 100 ΠΈ ΠΊΠΎΠΌΠ°Π½Π΄Π° % 10, Ρ.Π΅. Π² Π½Π°ΡΠΈΡ ΡΠ»ΡΡΠ°ΠΉ 1, 6 ΠΈ 1. Π’Π΅Π·ΠΈ ΡΡΠΈ ΡΠΈΡΠ»Π°, ΠΊΠ°ΠΊΡΠΎ ΠΈ ΡΠΊΠ°Π·Π°ΡΠ΅Π» ΠΊΡΠΌ JNIEnv ΠΈ Π°ΡΠ³ΡΠΌΠ΅Π½ΡΠΈΡΠ΅, ΠΏΡΠ΅Π΄Π°Π΄Π΅Π½ΠΈ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ°, ΡΠ΅ Π΄ΠΎΠ±Π°Π²ΡΡ ΠΊΡΠΌ ΡΡΡΡΠΊΡΡΡΠ° ΠΈ ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π°Ρ Π½Π°ΡΠ°ΡΡΠΊ. Π‘ ΠΏΠΎΠΌΠΎΡΡΠ° Π½Π° ΠΏΠΎΠ»ΡΡΠ΅Π½ΠΈΡΠ΅ ΡΡΠΈ ΡΠΈΡΠ»Π° (Π½Π΅ΠΊΠ° Π³ΠΈ ΠΎΠ±ΠΎΠ·Π½Π°ΡΠΈΠΌ Ρ N1, N2 ΠΈ N3) ΡΠ΅ ΠΈΠ·Π³ΡΠ°ΠΆΠ΄Π° ΠΊΠΎΠΌΠ°Π½Π΄Π½ΠΎ Π΄ΡΡΠ²ΠΎ.
ΠΠ΅ΡΠΎ ΠΊΠ°ΡΠΎ ΡΠΎΠ²Π°:
ΠΡΡΠ²ΠΎΡΠΎ ΡΠ΅ ΠΏΠΎΠΏΡΠ»Π²Π° Π΄ΠΈΠ½Π°ΠΌΠΈΡΠ½ΠΎ JNI_OnLoad.
Π’ΡΠΈ ΡΠΈΡΠ»Π° ΠΊΠΎΠ΄ΠΈΡΠ°Ρ ΠΏΡΡΡ Π² Π΄ΡΡΠ²ΠΎΡΠΎ. ΠΡΡΠΊΠΎ Π»ΠΈΡΡΠΎ Π½Π° Π΄ΡΡΠ²ΠΎΡΠΎ ΡΡΠ΄ΡΡΠΆΠ° Π²Π³ΡΠ°Π΄Π΅Π½ΠΈΡ Π°Π΄ΡΠ΅Ρ Π½Π° ΡΡΠΎΡΠ²Π΅ΡΠ½Π°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ. ΠΠ»ΡΡΡΡ Π΅ Π² ΡΠΎΠ΄ΠΈΡΠ΅Π»ΡΠΊΠΈΡ Π²ΡΠ·Π΅Π». ΠΠ°ΠΌΠΈΡΠ°Π½Π΅ΡΠΎ Π½Π° ΠΌΡΡΡΠΎΡΠΎ Π² ΠΊΠΎΠ΄Π°, ΠΊΡΠ΄Π΅ΡΠΎ ΡΡΠ½ΠΊΡΠΈΡΡΠ°, ΠΎΡ ΠΊΠΎΡΡΠΎ ΡΠ΅ Π½ΡΠΆΠ΄Π°Π΅ΠΌ, Π΅ Π΄ΠΎΠ±Π°Π²Π΅Π½Π° ΠΊΡΠΌ Π΄ΡΡΠ²ΠΎΡΠΎ, Π½Π΅ Π΅ ΡΡΡΠ΄Π½ΠΎ, Π°ΠΊΠΎ ΡΠ°Π·Π±ΠΈΡΠ°ΡΠ΅ Π²ΡΠΈΡΠΊΠΈ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Π½ΠΈ ΡΡΡΡΠΊΡΡΡΠΈ (Π½ΠΈΠ΅ Π½Π΅ Π³ΠΈ ΠΎΠΏΠΈΡΠ²Π°ΠΌΠ΅, Π·Π° Π΄Π° Π½Π΅ ΡΠ°Π·Π΄ΡΠ²Π°ΠΌΠ΅ Π²Π΅ΡΠ΅ Π΄ΠΎΡΡΠ° Π³ΠΎΠ»ΡΠΌΠ° ΡΡΠ°ΡΠΈΡ).
ΠΡΠ΅ ΠΎΠ±ΡΡΠΊΠ²Π°Π½Π΅
ΠΠΎΠ»ΡΡΠΈΡ ΠΌΠ΅ Π°Π΄ΡΠ΅ΡΠ° Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ°, ΠΊΠΎΡΡΠΎ ΡΡΡΠ±Π²Π° Π΄Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ° ΡΡΠ°ΡΠΈΠΊΠ°: 0x5F1AC. ΠΠΎ Π΅ ΡΠ²ΡΡΠ΄Π΅ ΡΠ°Π½ΠΎ Π΄Π° ΡΠ΅ ΡΠ°Π΄Π²Π°ΠΌΠ΅: ΡΠ°Π·ΡΠ°Π±ΠΎΡΡΠΈΡΠΈΡΠ΅ Π½Π° UC Browser ΡΠ° ΠΏΠΎΠ΄Π³ΠΎΡΠ²ΠΈΠ»ΠΈ ΠΎΡΠ΅ Π΅Π΄Π½Π° ΠΈΠ·Π½Π΅Π½Π°Π΄Π° Π·Π° Π½Π°Ρ.
Π‘Π»Π΅Π΄ ΠΏΠΎΠ»ΡΡΠ°Π²Π°Π½Π΅ Π½Π° ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈΡΠ΅ ΠΎΡ ΠΌΠ°ΡΠΈΠ²Π°, ΠΊΠΎΠΉΡΠΎ Π΅ ΡΠΎΡΠΌΠΈΡΠ°Π½ Π² Java ΠΊΠΎΠ΄Π°, ΠΏΠΎΠ»ΡΡΠ°Π²Π°ΠΌΠ΅
ΠΊΡΠΌ ΡΡΠ½ΠΊΡΠΈΡΡΠ° Π½Π° Π°Π΄ΡΠ΅Ρ 0x4D070. Π ΡΡΠΊ Π½ΠΈ ΠΎΡΠ°ΠΊΠ²Π° Π΄ΡΡΠ³ ΡΠΈΠΏ ΠΎΠ±ΡΡΡΠΊΠ°ΡΠΈΡ Π½Π° ΠΊΠΎΠ΄Π°.
ΠΠΎΡΡΠ°Π²ΡΠΌΠ΅ Π΄Π²Π° ΠΈΠ½Π΄Π΅ΠΊΡΠ° Π² R7 ΠΈ R4:
ΠΡΠ΅ΠΌΠ΅ΡΡΠ²Π°ΠΌΠ΅ ΠΏΡΡΠ²ΠΈΡ ΠΈΠ½Π΄Π΅ΠΊΡ ΠΊΡΠΌ R11:
ΠΠ° Π΄Π° ΠΏΠΎΠ»ΡΡΠΈΡΠ΅ Π°Π΄ΡΠ΅Ρ ΠΎΡ ΡΠ°Π±Π»ΠΈΡΠ°, ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°ΠΉΡΠ΅ ΠΈΠ½Π΄Π΅ΠΊΡ:
Π‘Π»Π΅Π΄ ΠΊΠ°ΡΠΎ ΠΎΡΠΈΠ΄Π΅ΡΠ΅ Π½Π° ΠΏΡΡΠ²ΠΈΡ Π°Π΄ΡΠ΅Ρ, ΡΠ΅ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° Π²ΡΠΎΡΠΈΡΡ ΠΈΠ½Π΄Π΅ΠΊΡ, ΠΊΠΎΠΉΡΠΎ Π΅ Π² R4. Π ΡΠ°Π±Π»ΠΈΡΠ°ΡΠ° ΠΈΠΌΠ° 230 Π΅Π»Π΅ΠΌΠ΅Π½ΡΠ°.
ΠΠ°ΠΊΠ²ΠΎ Π΄Π° ΠΏΡΠ°Π²ΠΈΠΌ ΠΏΠΎ Π²ΡΠΏΡΠΎΡΠ°? ΠΠΎΠΆΠ΅ΡΠ΅ Π΄Π° ΠΊΠ°ΠΆΠ΅ΡΠ΅ Π½Π° IDA, ΡΠ΅ ΡΠΎΠ²Π° Π΅ ΠΏΡΠ΅Π²ΠΊΠ»ΡΡΠ²Π°ΡΠ΅Π»: Edit -> Other -> Specify switch idiom.
ΠΠΎΠ»ΡΡΠ΅Π½ΠΈΡΡ ΠΊΠΎΠ΄ Π΅ ΡΠΆΠ°ΡΠ΅Π½. ΠΠΎ, ΠΏΡΠΎΠΏΡΠ°Π²ΡΠΉΠΊΠΈ ΡΠΈ ΠΏΡΡ ΠΏΡΠ΅Π· Π΄ΠΆΡΠ½Π³Π»Π°ΡΠ° ΠΌΡ, ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° Π·Π°Π±Π΅Π»Π΅ΠΆΠΈΡΠ΅ ΠΈΠ·Π²ΠΈΠΊΠ²Π°Π½Π΅ Π½Π° ΡΡΠ½ΠΊΡΠΈΡ, ΠΊΠΎΡΡΠΎ Π²Π΅ΡΠ΅ Π½ΠΈ Π΅ ΠΏΠΎΠ·Π½Π°ΡΠ° sub_6115C:
ΠΠΌΠ°ΡΠ΅ ΠΏΡΠ΅Π²ΠΊΠ»ΡΡΠ²Π°ΡΠ΅Π», Π² ΠΊΠΎΠΉΡΠΎ Π² ΡΠ»ΡΡΠ°ΠΉ 3 ΠΈΠΌΠ°ΡΠ΅ Π΄Π΅ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π΅ Ρ ΠΏΠΎΠΌΠΎΡΡΠ° Π½Π° Π°Π»Π³ΠΎΡΠΈΡΡΠΌΠ° RC4. Π Π² ΡΠΎΠ·ΠΈ ΡΠ»ΡΡΠ°ΠΉ ΡΡΡΡΠΊΡΡΡΠ°ΡΠ°, ΠΏΡΠ΅Π΄Π°Π΄Π΅Π½Π° Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ°, ΡΠ΅ Π·Π°ΠΏΡΠ»Π²Π° ΠΎΡ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈΡΠ΅, ΠΏΡΠ΅Π΄Π°Π΄Π΅Π½ΠΈ Π½Π° doCommandNative. ΠΠ° ΡΠΈ ΡΠΏΠΎΠΌΠ½ΠΈΠΌ ΠΊΠ°ΠΊΠ²ΠΎ ΠΈΠΌΠ°Ρ
ΠΌΠ΅ ΡΠ°ΠΌ magicInt ΡΡΡ ΡΡΠΎΠΉΠ½ΠΎΡΡ 16. Π Π°Π·Π³Π»Π΅ΠΆΠ΄Π°ΠΌΠ΅ ΡΡΠΎΡΠ²Π΅ΡΠ½ΠΈΡ ΡΠ»ΡΡΠ°ΠΉ - ΠΈ ΡΠ»Π΅Π΄ Π½ΡΠΊΠΎΠ»ΠΊΠΎ ΠΏΡΠ΅Ρ
ΠΎΠ΄Π° Π½Π°ΠΌΠΈΡΠ°ΠΌΠ΅ ΠΊΠΎΠ΄Π°, ΠΏΠΎ ΠΊΠΎΠΉΡΠΎ Π°Π»Π³ΠΎΡΠΈΡΡΠΌΡΡ ΠΌΠΎΠΆΠ΅ Π΄Π° Π±ΡΠ΄Π΅ ΠΈΠ΄Π΅Π½ΡΠΈΡΠΈΡΠΈΡΠ°Π½.
Π’ΠΎΠ²Π° Π΅ AES!
ΠΠ»Π³ΠΎΡΠΈΡΡΠΌΡΡ ΡΡΡΠ΅ΡΡΠ²ΡΠ²Π°, ΠΎΡΡΠ°Π²Π° ΡΠ°ΠΌΠΎ Π΄Π° ΡΠ΅ ΠΏΠΎΠ»ΡΡΠ°Ρ Π½Π΅Π³ΠΎΠ²ΠΈΡΠ΅ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ: ΡΠ΅ΠΆΠΈΠΌ, ΠΊΠ»ΡΡ ΠΈ, Π΅Π²Π΅Π½ΡΡΠ°Π»Π½ΠΎ, Π²Π΅ΠΊΡΠΎΡ Π·Π° ΠΈΠ½ΠΈΡΠΈΠ°Π»ΠΈΠ·Π°ΡΠΈΡ (Π½Π΅Π³ΠΎΠ²ΠΎΡΠΎ ΠΏΡΠΈΡΡΡΡΠ²ΠΈΠ΅ Π·Π°Π²ΠΈΡΠΈ ΠΎΡ ΡΠ΅ΠΆΠΈΠΌΠ° Π½Π° ΡΠ°Π±ΠΎΡΠ° Π½Π° Π°Π»Π³ΠΎΡΠΈΡΡΠΌΠ° AES). Π‘ΡΡΡΠΊΡΡΡΠ°ΡΠ° Ρ ΡΡΡ ΡΡΡΠ±Π²Π° Π΄Π° ΡΠ΅ ΡΠΎΡΠΌΠΈΡΠ° Π½ΡΠΊΡΠ΄Π΅ ΠΏΡΠ΅Π΄ΠΈ ΠΈΠ·Π²ΠΈΠΊΠ²Π°Π½Π΅ΡΠΎ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° sub_6115C, Π½ΠΎ ΡΠ°Π·ΠΈ ΡΠ°ΡΡ ΠΎΡ ΠΊΠΎΠ΄Π° Π΅ ΠΎΡΠΎΠ±Π΅Π½ΠΎ Π΄ΠΎΠ±ΡΠ΅ ΠΎΠ±ΡΡΡΡΠΈΡΠ°Π½Π°, ΡΠ°ΠΊΠ° ΡΠ΅ Π²ΡΠ·Π½ΠΈΠΊΠ²Π° ΠΈΠ΄Π΅ΡΡΠ° Π΄Π° ΡΠ΅ ΠΊΠΎΡΠΈΠ³ΠΈΡΠ° ΠΊΠΎΠ΄ΡΡ, ΡΠ°ΠΊΠ° ΡΠ΅ Π²ΡΠΈΡΠΊΠΈ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° Π·Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½Π΅ Π΄Π° Π±ΡΠ΄Π°Ρ ΠΈΠ·Ρ Π²ΡΡΠ»Π΅Π½ΠΈ Π²ΡΠ² ΡΠ°ΠΉΠ».
ΠΊΡΡΠΏΠΊΠ°
ΠΠ° Π΄Π° Π½Π΅ ΠΏΠΈΡΠ΅ΡΠ΅ ΡΠ΅Π»ΠΈΡ ΠΊΠΎΠ΄ Π½Π° ΠΊΠΎΡΠ΅ΠΊΡΠΈΡΡΠ° Π½Π° Π°ΡΠ΅ΠΌΠ±Π»Π΅Ρ ΡΡΡΠ½ΠΎ, ΠΌΠΎΠΆΠ΅ΡΠ΅ Π΄Π° ΡΡΠ°ΡΡΠΈΡΠ°ΡΠ΅ Android Studio, Π΄Π° Π½Π°ΠΏΠΈΡΠ΅ΡΠ΅ ΡΠ°ΠΌ ΡΡΠ½ΠΊΡΠΈΡ, ΠΊΠΎΡΡΠΎ ΠΏΠΎΠ»ΡΡΠ°Π²Π° ΡΡΡΠΈΡΠ΅ Π²Ρ ΠΎΠ΄Π½ΠΈ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ ΠΊΠ°ΡΠΎ Π½Π°ΡΠ°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ Π·Π° Π΄Π΅ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π΅ ΠΈ Π·Π°ΠΏΠΈΡΠ²Π° Π²ΡΠ² ΡΠ°ΠΉΠ», ΡΠ»Π΅Π΄ ΠΊΠΎΠ΅ΡΠΎ ΠΊΠΎΠΏΠΈΡΠ°ΠΉΡΠ΅ ΠΈ ΠΏΠΎΡΡΠ°Π²Π΅ΡΠ΅ ΠΊΠΎΠ΄Π°, ΠΊΠΎΠΉΡΠΎ ΠΊΠΎΠΌΠΏΠΈΠ»Π°ΡΠΎΡΡΡ ΡΠ΅ Π³Π΅Π½Π΅ΡΠΈΡΠ°ΠΌ.
ΠΠ° ΡΠ΄ΠΎΠ±ΡΡΠ²ΠΎΡΠΎ ΠΏΡΠΈ Π΄ΠΎΠ±Π°Π²ΡΠ½Π΅ Π½Π° ΠΊΠΎΠ΄ ΡΠ΅ ΠΏΠΎΠ³ΡΠΈΠΆΠΈΡ Π° ΠΈ Π½Π°ΡΠΈΡΠ΅ ΠΏΡΠΈΡΡΠ΅Π»ΠΈ ΠΎΡ Π΅ΠΊΠΈΠΏΠ° Π½Π° UC Browser. ΠΠ΅ΠΊΠ° ΡΠΈ ΠΏΡΠΈΠΏΠΎΠΌΠ½ΠΈΠΌ, ΡΠ΅ Π² Π½Π°ΡΠ°Π»ΠΎΡΠΎ Π½Π° Π²ΡΡΠΊΠ° ΡΡΠ½ΠΊΡΠΈΡ ΠΈΠΌΠ°ΠΌΠ΅ ΠΊΠΎΠ΄ Π·Π° Π±ΠΎΠΊΠ»ΡΠΊ, ΠΊΠΎΠΉΡΠΎ Π»Π΅ΡΠ½ΠΎ ΠΌΠΎΠΆΠ΅ Π΄Π° Π±ΡΠ΄Π΅ Π·Π°ΠΌΠ΅Π½Π΅Π½ Ρ Π²ΡΠ΅ΠΊΠΈ Π΄ΡΡΠ³. ΠΠ½ΠΎΠ³ΠΎ ΡΠ΄ΠΎΠ±Π½ΠΎ π Π Π½Π°ΡΠ°Π»ΠΎΡΠΎ Π½Π° ΡΠ΅Π»Π΅Π²Π°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ ΠΎΠ±Π°ΡΠ΅ Π½ΡΠΌΠ° Π΄ΠΎΡΡΠ°ΡΡΡΠ½ΠΎ ΠΌΡΡΡΠΎ Π·Π° ΠΊΠΎΠ΄Π°, ΠΊΠΎΠΉΡΠΎ Π·Π°ΠΏΠΈΡΠ²Π° Π²ΡΠΈΡΠΊΠΈ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ Π²ΡΠ² ΡΠ°ΠΉΠ». Π’ΡΡΠ±Π²Π°ΡΠ΅ Π΄Π° Π³ΠΎ ΡΠ°Π·Π΄Π΅Π»Ρ Π½Π° ΡΠ°ΡΡΠΈ ΠΈ Π΄Π° ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°ΠΌ Π±Π»ΠΎΠΊΠΎΠ²Π΅ Π±ΠΎΠΊΠ»ΡΠΊ ΠΎΡ ΡΡΡΠ΅Π΄Π½ΠΈ ΡΡΠ½ΠΊΡΠΈΠΈ. ΠΠΌΠ°ΡΠ΅ ΠΎΠ±ΡΠΎ ΡΠ΅ΡΠΈΡΠΈ ΡΠ°ΡΡΠΈ.
ΠΡΡΠ²Π°ΡΠ° ΡΠ°ΡΡ:
Π Π°ΡΡ
ΠΈΡΠ΅ΠΊΡΡΡΠ°ΡΠ° ARM ΠΏΡΡΠ²ΠΈΡΠ΅ ΡΠ΅ΡΠΈΡΠΈ ΡΡΠ½ΠΊΡΠΈΠΎΠ½Π°Π»Π½ΠΈ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΡΠ° ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π°Ρ ΠΏΡΠ΅Π· ΡΠ΅Π³ΠΈΡΡΡΠΈΡΠ΅ R0-R3, ΠΎΡΡΠ°Π½Π°Π»ΠΈΡΠ΅, Π°ΠΊΠΎ ΠΈΠΌΠ° ΡΠ°ΠΊΠΈΠ²Π°, ΡΠ΅ ΠΏΡΠ΅Π΄Π°Π²Π°Ρ ΠΏΡΠ΅Π· ΡΡΠ΅ΠΊΠ°. Π Π΅Π³ΠΈΡΡΡΡΡΡ LR Π½ΠΎΡΠΈ ΠΎΠ±ΡΠ°ΡΠ½ΠΈΡ Π°Π΄ΡΠ΅Ρ. ΠΡΠΈΡΠΊΠΎ ΡΠΎΠ²Π° ΡΡΡΠ±Π²Π° Π΄Π° Π±ΡΠ΄Π΅ Π·Π°ΠΏΠ°Π·Π΅Π½ΠΎ, Π·Π° Π΄Π° ΠΌΠΎΠΆΠ΅ ΡΡΠ½ΠΊΡΠΈΡΡΠ° Π΄Π° ΡΠ°Π±ΠΎΡΠΈ, ΡΠ»Π΅Π΄ ΠΊΠ°ΡΠΎ ΠΈΠ·Ρ
Π²ΡΡΠ»ΠΈΠΌ Π½Π΅ΠΉΠ½ΠΈΡΠ΅ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ. Π‘ΡΡΠΎ ΡΠ°ΠΊΠ° ΡΡΡΠ±Π²Π° Π΄Π° Π·Π°ΠΏΠ°Π·ΠΈΠΌ Π²ΡΠΈΡΠΊΠΈ ΡΠ΅Π³ΠΈΡΡΡΠΈ, ΠΊΠΎΠΈΡΠΎ ΡΠ΅ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°ΠΌΠ΅ Π² ΠΏΡΠΎΡΠ΅ΡΠ°, ΡΠ°ΠΊΠ° ΡΠ΅ ΠΏΡΠ°Π²ΠΈΠΌ PUSH.W {R0-R10,LR}. Π R7 ΠΏΠΎΠ»ΡΡΠ°Π²Π°ΠΌΠ΅ Π°Π΄ΡΠ΅ΡΠ° Π½Π° ΡΠΏΠΈΡΡΠΊΠ° Ρ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΠΈ, ΠΏΡΠ΅Π΄Π°Π΄Π΅Π½ΠΈ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° ΡΡΠ΅Π· ΡΡΠ΅ΠΊΠ°.
ΠΠ·ΠΏΠΎΠ»Π·Π²Π°Π½Π΅ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° fopen Π΄Π° ΠΎΡΠ²ΠΎΡΠΈΠΌ ΡΠ°ΠΉΠ»Π° /Π΄Π°Π½Π½ΠΈ/Π»ΠΎΠΊΠ°Π»Π½ΠΈ/tmp/aes Π² ΡΠ΅ΠΆΠΈΠΌ "ab".
Ρ.Π΅. Π·Π° Π΄ΠΎΠ±Π°Π²ΡΠ½Π΅. Π R0 Π·Π°ΡΠ΅ΠΆΠ΄Π°ΠΌΠ΅ Π°Π΄ΡΠ΅ΡΠ° Π½Π° ΠΈΠΌΠ΅ΡΠΎ Π½Π° ΡΠ°ΠΉΠ»Π°, Π² R1 - Π°Π΄ΡΠ΅ΡΠ° Π½Π° ΡΠ΅Π΄Π°, ΠΏΠΎΠΊΠ°Π·Π²Π°Ρ ΡΠ΅ΠΆΠΈΠΌΠ°. Π ΡΡΠΊ ΠΊΠΎΠ΄ΡΡ Π·Π° Π±ΠΎΠΊΠ»ΡΠΊ ΡΠ²ΡΡΡΠ²Π°, ΡΠ°ΠΊΠ° ΡΠ΅ ΠΏΡΠ΅ΠΌΠΈΠ½Π°Π²Π°ΠΌΠ΅ ΠΊΡΠΌ ΡΠ»Π΅Π΄Π²Π°ΡΠ°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ. ΠΠ° Π΄Π° ΠΏΡΠΎΠ΄ΡΠ»ΠΆΠΈ Π΄Π° ΡΠ°Π±ΠΎΡΠΈ, ΠΏΠΎΡΡΠ°Π²ΡΠΌΠ΅ Π² Π½Π°ΡΠ°Π»ΠΎΡΠΎ ΠΏΡΠ΅Ρ
ΠΎΠ΄Π° ΠΊΡΠΌ ΡΠ΅Π°Π»Π½ΠΈΡ ΠΊΠΎΠ΄ Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ°, Π·Π°ΠΎΠ±ΠΈΠΊΠ°Π»ΡΠΉΠΊΠΈ Π±ΠΎΠΊΠ»ΡΠΊΠ°, Π° Π²ΠΌΠ΅ΡΡΠΎ Π±ΠΎΠΊΠ»ΡΠΊΠ° Π΄ΠΎΠ±Π°Π²ΡΠΌΠ΅ ΠΏΡΠΎΠ΄ΡΠ»ΠΆΠ΅Π½ΠΈΠ΅ Π½Π° ΠΊΠΎΡΠ΅ΠΊΡΠΈΡΡΠ°.
ΠΠ±Π°ΠΆΠ΄Π°ΠΌΠ΅ ΡΠ΅ fopen.
ΠΡΡΠ²ΠΈΡΠ΅ ΡΡΠΈ ΠΏΠ°ΡΠ°ΠΌΠ΅ΡΡΡΠ° Π½Π° ΡΡΠ½ΠΊΡΠΈΡΡΠ° AES ΠΈΠΌΠ°Ρ ΡΠΈΠΏ Int. Π’ΡΠΉ ΠΊΠ°ΡΠΎ Π·Π°ΠΏΠΈΡΠ°Ρ ΠΌΠ΅ ΡΠ΅Π³ΠΈΡΡΡΠΈΡΠ΅ Π² ΡΡΠ΅ΠΊΠ° Π² Π½Π°ΡΠ°Π»ΠΎΡΠΎ, ΠΌΠΎΠΆΠ΅ΠΌ ΠΏΡΠΎΡΡΠΎ Π΄Π° ΠΏΡΠ΅Π΄Π°Π΄Π΅ΠΌ ΡΡΠ½ΠΊΡΠΈΡΡΠ° fwrite ΡΠ΅Ρ Π½ΠΈΡΠ΅ Π°Π΄ΡΠ΅ΡΠΈ Π² ΡΡΠ΅ΠΊΠ°.
Π‘Π»Π΅Π΄ ΡΠΎΠ²Π° ΠΈΠΌΠ°ΠΌΠ΅ ΡΡΠΈ ΡΡΡΡΠΊΡΡΡΠΈ, ΠΊΠΎΠΈΡΠΎ ΡΡΠ΄ΡΡΠΆΠ°Ρ ΡΠ°Π·ΠΌΠ΅ΡΠ° Π½Π° Π΄Π°Π½Π½ΠΈΡΠ΅ ΠΈ ΡΠΊΠ°Π·Π°ΡΠ΅Π» ΠΊΡΠΌ Π΄Π°Π½Π½ΠΈΡΠ΅ Π·Π° ΠΊΠ»ΡΡΠ°, Π²Π΅ΠΊΡΠΎΡ Π·Π° ΠΈΠ½ΠΈΡΠΈΠ°Π»ΠΈΠ·Π°ΡΠΈΡ ΠΈ ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½ΠΈ Π΄Π°Π½Π½ΠΈ.
ΠΠ°ΠΊΡΠ°Ρ Π·Π°ΡΠ²ΠΎΡΠ΅ΡΠ΅ ΡΠ°ΠΉΠ»Π°, Π²ΡΠ·ΡΡΠ°Π½ΠΎΠ²Π΅ΡΠ΅ ΡΠ΅Π³ΠΈΡΡΡΠΈΡΠ΅ ΠΈ ΠΏΡΠ΅Ρ
Π²ΡΡΠ»Π΅ΡΠ΅ ΡΠΏΡΠ°Π²Π»Π΅Π½ΠΈΠ΅ΡΠΎ Π½Π° ΡΠ΅Π°Π»Π½Π°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ AES.
Π‘ΡΠ±ΠΈΡΠ°ΠΌΠ΅ APK Ρ ΠΏΠ°ΡΠ²Π°Π½Π° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°, ΠΏΠΎΠ΄ΠΏΠΈΡΠ²Π°ΠΌΠ΅ Π³ΠΎ, ΠΊΠ°ΡΠ²Π°ΠΌΠ΅ Π³ΠΎ Π½Π° ΡΡΡΡΠΎΠΉΡΡΠ²ΠΎΡΠΎ/Π΅ΠΌΡΠ»Π°ΡΠΎΡΠ° ΠΈ Π³ΠΎ ΡΡΠ°ΡΡΠΈΡΠ°ΠΌΠ΅. ΠΠΈΠΆΠ΄Π°ΠΌΠ΅, ΡΠ΅ Π½Π°ΡΠΈΡΡ Π΄ΡΠΌΠΏ ΡΠ΅ ΡΡΠ·Π΄Π°Π²Π° ΠΈ ΡΠ°ΠΌ ΡΠ΅ Π·Π°ΠΏΠΈΡΠ²Π°Ρ ΠΌΠ½ΠΎΠ³ΠΎ Π΄Π°Π½Π½ΠΈ. ΠΡΠ°ΡΠ·ΡΡΡΡ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π΅ Π½Π΅ ΡΠ°ΠΌΠΎ Π·Π° ΡΡΠ°ΡΠΈΠΊΠ°, Π° ΡΡΠ»ΠΎΡΠΎ ΠΊΡΠΈΠΏΡΠΈΡΠ°Π½Π΅ ΠΌΠΈΠ½Π°Π²Π° ΠΏΡΠ΅Π· Π²ΡΠΏΡΠΎΡΠ½Π°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ. ΠΠΎ ΠΏΠΎ Π½ΡΠΊΠ°ΠΊΠ²Π° ΠΏΡΠΈΡΠΈΠ½Π° Π½Π΅ΠΎΠ±Ρ ΠΎΠ΄ΠΈΠΌΠΈΡΠ΅ Π΄Π°Π½Π½ΠΈ Π½Π΅ ΡΠ° ΡΠ°ΠΌ ΠΈ Π½Π΅ΠΎΠ±Ρ ΠΎΠ΄ΠΈΠΌΠ°ΡΠ° Π·Π°ΡΠ²ΠΊΠ° Π½Π΅ ΡΠ΅ Π²ΠΈΠΆΠ΄Π° Π² ΡΡΠ°ΡΠΈΠΊΠ°. ΠΠ° Π΄Π° Π½Π΅ ΡΠ°ΠΊΠ°ΠΌΠ΅, Π΄ΠΎΠΊΠ°ΡΠΎ UC Browser Π±Π»Π°Π³ΠΎΠ²ΠΎΠ»ΠΈ Π΄Π° Π½Π°ΠΏΡΠ°Π²ΠΈ Π½Π΅ΠΎΠ±Ρ ΠΎΠ΄ΠΈΠΌΠ°ΡΠ° Π·Π°ΡΠ²ΠΊΠ°, Π½Π΅ΠΊΠ° Π²Π·Π΅ΠΌΠ΅ΠΌ ΡΠΈΡΡΠΎΠ²Π°Π½ΠΈΡ ΠΎΡΠ³ΠΎΠ²ΠΎΡ ΠΎΡ ΡΡΡΠ²ΡΡΠ°, ΠΏΠΎΠ»ΡΡΠ΅Π½ ΠΏΠΎ-ΡΠ°Π½ΠΎ, ΠΈ ΠΎΡΠ½ΠΎΠ²ΠΎ Π΄Π° Π·Π°ΠΊΡΡΠΏΠΈΠΌ ΠΏΡΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅ΡΠΎ: Π΄ΠΎΠ±Π°Π²Π΅ΡΠ΅ Π΄Π΅ΡΠΈΡΡΠΈΡΠ°Π½Π΅ΡΠΎ ΠΊΡΠΌ onCreate Π½Π° ΠΎΡΠ½ΠΎΠ²Π½Π°ΡΠ° Π΄Π΅ΠΉΠ½ΠΎΡΡ.
const/16 v1, 0x62
new-array v1, v1, [B
fill-array-data v1, :encrypted_data
const/16 v0, 0x1f
invoke-static {v0, v1}, Lcom/uc/browser/core/d/c/g;->j(I[B)[B
move-result-object v1
array-length v2, v1
invoke-static {v2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v2
const-string v0, "ololo"
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
Π‘Π³Π»ΠΎΠ±ΡΠ²Π°ΠΌΠ΅, ΠΏΠΎΠ΄ΠΏΠΈΡΠ²Π°ΠΌΠ΅, ΠΈΠ½ΡΡΠ°Π»ΠΈΡΠ°ΠΌΠ΅, ΠΏΡΡΠΊΠ°ΠΌΠ΅. ΠΠΎΠ»ΡΡΠ°Π²Π°ΠΌΠ΅ NullPointerException, Π·Π°ΡΠΎΡΠΎ ΠΌΠ΅ΡΠΎΠ΄ΡΡ Π²ΡΡΠ½Π° Π½ΡΠ»Π°.
ΠΠΎ Π²ΡΠ΅ΠΌΠ΅ Π½Π° ΠΏΠΎ-Π½Π°ΡΠ°ΡΡΡΠ½ΠΈΡ Π°Π½Π°Π»ΠΈΠ· Π½Π° ΠΊΠΎΠ΄Π° Π±Π΅ΡΠ΅ ΠΎΡΠΊΡΠΈΡΠ° ΡΡΠ½ΠΊΡΠΈΡ, ΠΊΠΎΡΡΠΎ Π΄Π΅ΡΠΈΡΡΠΈΡΠ° ΠΈΠ½ΡΠ΅ΡΠ΅ΡΠ½ΠΈ ΡΠ΅Π΄ΠΎΠ²Π΅: βMETA-INF/β ΠΈ β.RSAβ. ΠΠ·Π³Π»Π΅ΠΆΠ΄Π°, ΡΠ΅ ΠΏΡΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅ΡΠΎ ΠΏΡΠΎΠ²Π΅ΡΡΠ²Π° ΡΠ²ΠΎΡ ΡΠ΅ΡΡΠΈΡΠΈΠΊΠ°Ρ. ΠΠ»ΠΈ Π΄ΠΎΡΠΈ Π³Π΅Π½Π΅ΡΠΈΡΠ° ΠΊΠ»ΡΡΠΎΠ²Π΅ ΠΎΡ Π½Π΅Π³ΠΎ. ΠΠ°ΠΈΡΡΠΈΠ½Π° Π½Π΅ ΠΈΡΠΊΠ°ΠΌ Π΄Π° ΡΠ΅ Π·Π°Π½ΠΈΠΌΠ°Π²Π°ΠΌ Ρ ΡΠΎΠ²Π°, ΠΊΠΎΠ΅ΡΠΎ ΡΠ΅ ΡΠ»ΡΡΠ²Π° ΡΡΡ ΡΠ΅ΡΡΠΈΡΠΈΠΊΠ°ΡΠ°, ΡΠ°ΠΊΠ° ΡΠ΅ ΠΏΡΠΎΡΡΠΎ ΡΠ΅ ΠΌΡ ΠΏΡΠ΅Π΄ΠΎΡΡΠ°Π²ΠΈΠΌ ΠΏΡΠ°Π²ΠΈΠ»Π½ΠΈΡ ΡΠ΅ΡΡΠΈΡΠΈΠΊΠ°Ρ. ΠΠ΅ΠΊΠ° Π·Π°ΠΊΡΡΠΏΠΈΠΌ ΡΠΈΡΡΠΎΠ²Π°Π½ΠΈΡ ΡΠ΅Π΄, ΡΠ°ΠΊΠ° ΡΠ΅ Π²ΠΌΠ΅ΡΡΠΎ βMETA-INF/β Π΄Π° ΠΏΠΎΠ»ΡΡΠΈΠΌ βBLABLINF/β, ΡΡΠ·Π΄Π°ΠΉΡΠ΅ ΠΏΠ°ΠΏΠΊΠ° Ρ ΡΠΎΠ²Π° ΠΈΠΌΠ΅ Π² APK ΠΈ Π΄ΠΎΠ±Π°Π²Π΅ΡΠ΅ ΡΠ΅ΡΡΠΈΡΠΈΠΊΠ°ΡΠ° Π½Π° Π±ΡΠ°ΡΠ·ΡΡΠ° Π½Π° ΠΊΠ°ΡΠ΅ΡΠΈΡΠ° ΡΠ°ΠΌ.
Π‘Π³Π»ΠΎΠ±ΡΠ²Π°ΠΌΠ΅, ΠΏΠΎΠ΄ΠΏΠΈΡΠ²Π°ΠΌΠ΅, ΠΌΠΎΠ½ΡΠΈΡΠ°ΠΌΠ΅, ΠΏΡΡΠΊΠ°ΠΌΠ΅. ΠΠΈΠ½Π³ΠΎ! ΠΠΈΠ΅ ΠΈΠΌΠ°ΠΌΠ΅ ΠΊΠ»ΡΡΠ°!
MitM
ΠΠΎΠ»ΡΡΠΈΡ ΠΌΠ΅ ΠΊΠ»ΡΡ ΠΈ Π²Π΅ΠΊΡΠΎΡ Π·Π° ΠΈΠ½ΠΈΡΠΈΠ°Π»ΠΈΠ·Π°ΡΠΈΡ, ΡΠ°Π²Π΅Π½ Π½Π° ΠΊΠ»ΡΡΠ°. ΠΠ΅ΠΊΠ° ΡΠ΅ ΠΎΠΏΠΈΡΠ°ΠΌΠ΅ Π΄Π° Π΄Π΅ΡΠΈΡΡΠΈΡΠ°ΠΌΠ΅ ΠΎΡΠ³ΠΎΠ²ΠΎΡΠ° Π½Π° ΡΡΡΠ²ΡΡΠ° Π² ΡΠ΅ΠΆΠΈΠΌ CBC.
ΠΠΈΠΆΠ΄Π°ΠΌΠ΅ URL Π°Π΄ΡΠ΅ΡΠ° Π½Π° Π°ΡΡ
ΠΈΠ²Π°, Π½Π΅ΡΠΎ ΠΏΠΎΠ΄ΠΎΠ±Π½ΠΎ Π½Π° MD5, βextract_unzipsizeβ ΠΈ ΡΠΈΡΠ»ΠΎ. ΠΡΠΎΠ²Π΅ΡΡΠ²Π°ΠΌΠ΅: MD5 Π½Π° Π°ΡΡ
ΠΈΠ²Π° Π΅ ΡΡΡΠΈΡΡ, ΡΠ°Π·ΠΌΠ΅ΡΡΡ Π½Π° ΡΠ°Π·ΠΎΠΏΠ°ΠΊΠΎΠ²Π°Π½Π°ΡΠ° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° Π΅ ΡΡΡΠΈΡΡ. ΠΠΏΠΈΡΠ²Π°ΠΌΠ΅ ΡΠ΅ Π΄Π° ΠΊΠΎΡΠΈΠ³ΠΈΡΠ°ΠΌΠ΅ ΡΠ°Π·ΠΈ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° ΠΈ Π΄Π° Ρ Π΄Π°Π΄Π΅ΠΌ Π½Π° Π±ΡΠ°ΡΠ·ΡΡΠ°. ΠΠ° Π΄Π° ΠΏΠΎΠΊΠ°ΠΆΠ΅ΠΌ, ΡΠ΅ Π½Π°ΡΠ°ΡΠ° Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ° Ρ ΠΊΠΎΡΠ΅ΠΊΡΠΈΠΈ ΡΠ΅ Π΅ Π·Π°ΡΠ΅Π΄ΠΈΠ»Π°, ΡΠ΅ ΡΡΠ°ΡΡΠΈΡΠ°ΠΌΠ΅ Π½Π°ΠΌΠ΅ΡΠ΅Π½ΠΈΠ΅ Π·Π° ΡΡΠ·Π΄Π°Π²Π°Π½Π΅ Π½Π° SMS Ρ ΡΠ΅ΠΊΡΡ βPWNED!β Π©Π΅ Π·Π°ΠΌΠ΅Π½ΠΈΠΌ Π΄Π²Π° ΠΎΡΠ³ΠΎΠ²ΠΎΡΠ° ΠΎΡ ΡΡΡΠ²ΡΡΠ°:
ΠΡΠ°ΡΠ·ΡΡΡΡ ΡΠ΅ ΠΎΠΏΠΈΡΠ²Π° Π΄Π° ΠΈΠ·ΡΠ΅Π³Π»ΠΈ Π°ΡΡ
ΠΈΠ²Π° Π½ΡΠΊΠΎΠ»ΠΊΠΎ ΠΏΡΡΠΈ, ΡΠ»Π΅Π΄ ΠΊΠΎΠ΅ΡΠΎ Π΄Π°Π²Π° Π³ΡΠ΅ΡΠΊΠ°. Π―Π²Π½ΠΎ Π½Π΅ΡΠΎ
ΡΠΎΠΉ Π½Π΅ Ρ
Π°ΡΠ΅ΡΠ²Π°. Π ΡΠ΅Π·ΡΠ»ΡΠ°Ρ Π½Π° Π°Π½Π°Π»ΠΈΠ·Π° Π½Π° ΡΠΎΠ·ΠΈ ΠΌΡΡΠ΅Π½ ΡΠΎΡΠΌΠ°Ρ ΡΠ΅ ΠΎΠΊΠ°Π·Π°, ΡΠ΅ ΡΡΡΠ²ΡΡΡΡ ΠΏΡΠ΅Π΄Π°Π²Π° ΠΈ ΡΠ°Π·ΠΌΠ΅ΡΠ° Π½Π° Π°ΡΡ
ΠΈΠ²Π°:
Π’ΠΎΠΉ Π΅ ΠΊΠΎΠ΄ΠΈΡΠ°Π½ Π² LEB128. Π‘Π»Π΅Π΄ ΠΊΠΎΡΠ΅ΠΊΡΠΈΡΡΠ° ΡΠ°Π·ΠΌΠ΅ΡΡΡ Π½Π° Π°ΡΡ
ΠΈΠ²Π° Ρ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°ΡΠ° ΡΠ΅ ΠΏΡΠΎΠΌΠ΅Π½ΠΈ ΠΌΠ°Π»ΠΊΠΎ, ΡΠ°ΠΊΠ° ΡΠ΅ Π±ΡΠ°ΡΠ·ΡΡΡΡ ΡΡΠ΅ΡΠ΅, ΡΠ΅ Π°ΡΡ
ΠΈΠ²ΡΡ Π΅ ΠΈΠ·ΡΠ΅Π³Π»Π΅Π½ Π½Π΅ΠΏΡΠ°Π²ΠΈΠ»Π½ΠΎ ΠΈ ΡΠ»Π΅Π΄ Π½ΡΠΊΠΎΠ»ΠΊΠΎ ΠΎΠΏΠΈΡΠ° ΠΈΠ·Π΄Π°Π΄Π΅ Π³ΡΠ΅ΡΠΊΠ°.
ΠΠΎΡΠΈΠ³ΠΈΡΠ°ΠΌΠ΅ ΡΠ°Π·ΠΌΠ΅ΡΠ° Π½Π° Π°ΡΡ ΠΈΠ²Π°... Π β ΠΏΠΎΠ±Π΅Π΄Π°! π Π Π΅Π·ΡΠ»ΡΠ°ΡΡΡ Π΅ Π²ΡΠ² Π²ΠΈΠ΄Π΅ΠΎΡΠΎ.
ΠΠΎΡΠ»Π΅Π΄ΠΈΡΠΈ ΠΈ ΡΠ΅Π°ΠΊΡΠΈΡ Π½Π° ΡΠ°Π·ΡΠ°Π±ΠΎΡΡΠΈΠΊΠ°
ΠΠΎ ΡΡΡΠΈΡ Π½Π°ΡΠΈΠ½ Ρ Π°ΠΊΠ΅ΡΠΈΡΠ΅ ΠΌΠΎΠ³Π°Ρ Π΄Π° ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Ρ Π½Π΅ΡΠΈΠ³ΡΡΠ½Π°ΡΠ° ΡΡΠ½ΠΊΡΠΈΡ Π½Π° UC Browser, Π·Π° Π΄Π° ΡΠ°Π·ΠΏΡΠΎΡΡΡΠ°Π½ΡΠ²Π°Ρ ΠΈ ΠΈΠ·ΠΏΡΠ»Π½ΡΠ²Π°Ρ Π·Π»ΠΎΠ½Π°ΠΌΠ΅ΡΠ΅Π½ΠΈ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠΈ. Π’Π΅Π·ΠΈ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠΈ ΡΠ΅ ΡΠ°Π±ΠΎΡΡΡ Π² ΠΊΠΎΠ½ΡΠ΅ΠΊΡΡΠ° Π½Π° Π±ΡΠ°ΡΠ·ΡΡΠ°, ΡΠ°ΠΊΠ° ΡΠ΅ ΡΠ΅ ΠΏΠΎΠ»ΡΡΠ°Ρ Π²ΡΠΈΡΠΊΠΈ Π½Π΅Π³ΠΎΠ²ΠΈ ΡΠΈΡΡΠ΅ΠΌΠ½ΠΈ ΡΠ°Π·ΡΠ΅ΡΠ΅Π½ΠΈΡ. Π ΡΠ΅Π·ΡΠ»ΡΠ°Ρ Π½Π° ΡΠΎΠ²Π° Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡΡΠ° Π·Π° ΠΏΠΎΠΊΠ°Π·Π²Π°Π½Π΅ Π½Π° ΡΠΈΡΠΈΠ½Π³ ΠΏΡΠΎΠ·ΠΎΡΡΠΈ, ΠΊΠ°ΠΊΡΠΎ ΠΈ Π΄ΠΎΡΡΡΠΏ Π΄ΠΎ ΡΠ°Π±ΠΎΡΠ½ΠΈΡΠ΅ ΡΠ°ΠΉΠ»ΠΎΠ²Π΅ Π½Π° ΠΎΡΠ°Π½ΠΆΠ΅Π²Π°ΡΠ° ΠΊΠΈΡΠ°ΠΉΡΠΊΠ° ΠΊΠ°ΡΠ΅ΡΠΈΡΠ°, Π²ΠΊΠ»ΡΡΠΈΡΠ΅Π»Π½ΠΎ Π²Π»ΠΈΠ·Π°Π½ΠΈΡ, ΠΏΠ°ΡΠΎΠ»ΠΈ ΠΈ Π±ΠΈΡΠΊΠ²ΠΈΡΠΊΠΈ, ΡΡΡ ΡΠ°Π½ΡΠ²Π°Π½ΠΈ Π² Π±Π°Π·Π°ΡΠ° Π΄Π°Π½Π½ΠΈ.
Π‘Π²ΡΡΠ·Π°Ρ
ΠΌΠ΅ ΡΠ΅ Ρ ΡΠ°Π·ΡΠ°Π±ΠΎΡΡΠΈΡΠΈΡΠ΅ Π½Π° UC Browser ΠΈ Π³ΠΈ ΠΈΠ½ΡΠΎΡΠΌΠΈΡΠ°Ρ
ΠΌΠ΅ Π·Π° ΠΏΡΠΎΠ±Π»Π΅ΠΌΠ°, ΠΊΠΎΠΉΡΠΎ ΠΎΡΠΊΡΠΈΡ
ΠΌΠ΅, ΠΎΠΏΠΈΡΠ°Ρ
ΠΌΠ΅ ΡΠ΅ Π΄Π° ΠΏΠΎΡΠΎΡΠΈΠΌ ΡΡΠ·Π²ΠΈΠΌΠΎΡΡΡΠ° ΠΈ Π½Π΅ΠΉΠ½Π°ΡΠ° ΠΎΠΏΠ°ΡΠ½ΠΎΡΡ, Π½ΠΎ ΡΠ΅ Π½Π΅ ΠΎΠ±ΡΡΠ΄ΠΈΡ
Π° Π½ΠΈΡΠΎ Ρ Π½Π°Ρ. ΠΠ΅ΠΆΠ΄ΡΠ²ΡΠ΅ΠΌΠ΅Π½Π½ΠΎ Π±ΡΠ°ΡΠ·ΡΡΡΡ ΠΏΡΠΎΠ΄ΡΠ»ΠΆΠΈ Π΄Π° ΠΏΠΎΠΊΠ°Π·Π²Π° ΠΎΠΏΠ°ΡΠ½Π°ΡΠ° ΡΠΈ ΡΡΠ½ΠΊΡΠΈΡ ΠΏΡΠ΅Π΄ ΠΎΡΠΈΡΠ΅. ΠΠΎ ΡΠ»Π΅Π΄ ΠΊΠ°ΡΠΎ ΡΠ°Π·ΠΊΡΠΈΡ
ΠΌΠ΅ ΠΏΠΎΠ΄ΡΠΎΠ±Π½ΠΎΡΡΠΈΡΠ΅ Π·Π° ΡΡΠ·Π²ΠΈΠΌΠΎΡΡΡΠ°, Π²Π΅ΡΠ΅ Π½Π΅ Π±Π΅ΡΠ΅ Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎ Π΄Π° Ρ ΠΈΠ³Π½ΠΎΡΠΈΡΠ°ΠΌΠ΅ ΠΊΠ°ΠΊΡΠΎ ΠΏΡΠ΅Π΄ΠΈ. 27 ΠΌΠ°ΡΡ Π±Π΅ΡΠ΅
Π±Π΅ΡΠ΅ ΠΏΡΡΠ½Π°ΡΠ° Π½ΠΎΠ²Π° Π²Π΅ΡΡΠΈΡ Π½Π° UC Browser 12.10.9.1193, ΠΊΠΎΡΡΠΎ ΠΎΡΡΡΠ΅ΡΡΠ²ΡΠ²Π° Π΄ΠΎΡΡΡΠΏ Π΄ΠΎ ΡΡΡΠ²ΡΡΠ° ΡΡΠ΅Π· HTTPS:
Π Π΄ΠΎΠΏΡΠ»Π½Π΅Π½ΠΈΠ΅, ΡΠ»Π΅Π΄ βΠΏΠΎΠΏΡΠ°Π²ΠΊΠ°ΡΠ°β ΠΈ Π΄ΠΎ ΠΌΠΎΠΌΠ΅Π½ΡΠ° Π½Π° Π½Π°ΠΏΠΈΡΠ²Π°Π½Π΅ Π½Π° ΡΠ°Π·ΠΈ ΡΡΠ°ΡΠΈΡ, ΠΎΠΏΠΈΡΡΡ Π·Π° ΠΎΡΠ²Π°ΡΡΠ½Π΅ Π½Π° PDF Π² Π±ΡΠ°ΡΠ·ΡΡ Π΄ΠΎΠ²Π΅Π΄Π΅ Π΄ΠΎ ΡΡΠΎΠ±ΡΠ΅Π½ΠΈΠ΅ Π·Π° Π³ΡΠ΅ΡΠΊΠ° Ρ ΡΠ΅ΠΊΡΡ βΠΠΌΠΈ ΡΠ΅Π³Π°, Π½Π΅ΡΠΎ ΡΠ΅ ΠΎΠ±ΡΡΠΊΠ°!β ΠΠ°ΡΠ²ΠΊΠ° ΠΊΡΠΌ ΡΡΡΠ²ΡΡΠ° Π½Π΅ Π΅ Π½Π°ΠΏΡΠ°Π²Π΅Π½Π° ΠΏΡΠΈ ΠΎΠΏΠΈΡ Π·Π° ΠΎΡΠ²Π°ΡΡΠ½Π΅ Π½Π° PDF, Π½ΠΎ Π΅ Π½Π°ΠΏΡΠ°Π²Π΅Π½Π° Π·Π°ΡΠ²ΠΊΠ° ΠΏΡΠΈ ΡΡΠ°ΡΡΠΈΡΠ°Π½Π΅ Π½Π° Π±ΡΠ°ΡΠ·ΡΡΠ°, ΠΊΠΎΠ΅ΡΠΎ Π½Π°ΠΌΠ΅ΠΊΠ²Π° Π·Π° ΠΏΡΠΎΠ΄ΡΠ»ΠΆΠ°Π²Π°ΡΠ°ΡΠ° Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡ Π·Π° ΠΈΠ·ΡΠ΅Π³Π»ΡΠ½Π΅ Π½Π° ΠΈΠ·ΠΏΡΠ»Π½ΠΈΠΌ ΠΊΠΎΠ΄ Π² Π½Π°ΡΡΡΠ΅Π½ΠΈΠ΅ Π½Π° ΠΏΡΠ°Π²ΠΈΠ»Π°ΡΠ° Π½Π° Google Play.
ΠΠ·ΡΠΎΡΠ½ΠΈΠΊ: www.habr.com