¿Algún programa para descompilar y modificar el código?

Iniciado por BotXaXa, 30 Julio 2016, 03:04 AM

0 Miembros y 1 Visitante están viendo este tema.

BotXaXa

Actualmente estudio programación y hace unos días se me ocurrió una idea, tras el famoso lanzamiento del juego "Pokémon Go" han salido aplicaciones de mapas que te dicen dónde se encuentran los Pokemon, este mapa tiene sus limitaciones por qué solo puede escanear un área, quiero descompilar el programa y modificar el código para quitarle estas limitaciones, así haría un escaneo a escala mundial. Tengo experiencia con Java Decompiler, ya que hace años me dedicaba a programar en la plataforma Bukkit y Spigot. Pero este programa no está hecho en lenguaje Java, me gustaría saber qué lenguaje es para saber si lo domino y si podría modificarlo. Gracias.

Poyoncio

#1
Si no sabes el lenguaje y tampoco das una referencia de la aplicacion nadie te podra ayudar  :P
Curso de ensamblador desde cero

Eleкtro

#2
Cita de: BotXaXa en 30 Julio 2016, 03:04 AMeste mapa tiene sus limitaciones por qué solo puede escanear un área, quiero descompilar el programa y modificar el código para quitarle estas limitaciones, así haría un escaneo a escala mundial.

Realmente no es una buena idea, ya que el rango de descubrimiento del mapa en un juego online por parte de un hack, se limita por un buen motivo: No acabar siendo baneado.

No solo en ese juego, sino en todos los demás del estilo que utilicen un mapa o mini mapa para descubrir enemigos, lugares y etc, el juego no es tonto, es un software y hay que verlo como tal, pudiendo tener sus algoritmos o métodos de protección anti-cheat, el juego debería detectar cierta actividad como el valor de ciertos parámetros que una vez sean manualmente modificados por una inyección decódigo o lo que sea, se registre una incidencia en el server, y entonces, si se detectase un rango de mapa visible que sea inusual acabarás baneado bien pronto, como ocurre en el resto de juegos.

En realidad no tengo ni la más mínima idea de como trabaja Pokémon Go! por que ni lo he jugado ni me he informado, yo solo te lo comento de forma general, por que en todos los juegos online que conozco donde hay mapa o minimapa, es bien sabido que modificar excesivamente el área de descubrimiento, lo que se conoce como la técnica "map reveal", implica un BAN directo por parte del server.

Además de eso, el simple hecho de querer utilizar el GPS de forma global, me parece que es demasiado... excesivo, imagínate el tiempo de respuesta de una petición como esa... suponiendo que realmente se pudiera hacer.




De todas formas, aquí tienes lo que preguntaste:
Cita de: https://www.quora.com/What-programming-language-was-used-to-code-Pok%C3%A9mon-GO/answer/Sean-Grogg
Client
Again, from their Employment page, it looks like they work with mobile application development using the Unity 3D Engine which supports C#, UnityScript (variant of javascript), or Boo - of which they are most likely using C#.

All told, Java seems to be the workhorse of Pokemon Go likely with some Objective-C/Swift specifically on the iOS development front.
Written 2w ago · View Upvotes

Saludos








Eleкtro

#3
Ah, bueno, discúlpame tu a mi por no entenderte correctamente, pero entonces, ¿estamos hablando de un paquete APK o de un cliente (EXE) para Windows?, en el primer caso, y junto a los conocimientos de Java, quizás esto te pueda servir:

-> instalador para windows: https://bintray.com/vaibhavpandeyvpz/generic/apkstudio/view

EDITO:
Supuestamente, y digo supuestamente por que nunca había intentado descompilar un APK hasta ahora, esto va así:

El paquete APK no es más que un contenedor zip, así que simplemente debes utilizar un descompresor de archivos o el programa apktool o apkstudio (que al parecer es un simple wrapper de apktool) para comprobar si existe un archivo llamado classes.dex, entonces lo extraes, y puedes convertir ese contenedor a formato Jar con la aplicación Dex2Jar: https://github.com/pxb1988/dex2jar/releases luego tienes que decompilar el archivo .Jar resultante, con DJ Java Decompiler o AndroChef Java Decompiler por ejemplo, entonces realizas las moificaciones que desees, reconstruyes el Jar con el mismo decompiler que usaste, reconstruyes el archivo dex con la otra aplicación, y por último reconstruyes el archivo APK con la aplicación que corresponda que ya mencioné al principio.

Ahora, puede darse el caso de que el archivo classes.dex no se encuentre en el interior del contenedor APK, de hecho eso parece ser lo más común, y entonces al parecer tienes que seguir los mismos pasos mencioandos, pero con un archivo que acabe en extensión ".odex"
Cita de: http://stackoverflow.com/questions/19887631/how-it-is-possible-that-apk-do-not-contain-classes-dex-but-worksQ: How it is possible that .apk do not contain classes.dex but works?
A: If dex-preoptimization is enabled (it's enabled by default in user builds), an .odex file (Email.odex for instance, just next to Email.apk) will be generated from the classes.dex and the original classes.dex is stripped from the apk.
+

Pero hay otro problema, se puede dar el caso en que un contenedor APK no contenga ni un archivo classes.dex ni ningún archivo acabado en extensión ".odex", y ahí ya si que no se que hacer.

Saludos!








Poyoncio

#4
Cita de: Eleкtro en 30 Julio 2016, 04:59 AM
Ah, bueno, discúlpame tu a mi por no entenderte correctamente, pero entonces, ¿estamos hablando de un paquete APK o de un cliente (EXE) para Windows?, en el primer caso, y junto a los conocimientos de Java, quizás esto te pueda servir:

-> instalador para windows: https://bintray.com/vaibhavpandeyvpz/generic/apkstudio/view

EDITO:
Supuestamente, y digo supuestamente por que nunca había intentado descompilar un APK hasta ahora, esto va así:

El paquete APK no es más que un contenedor zip, así que simplemente debes utilizar un descompresor de archivos o el programa apktool o apkstudio (que al parecer es un simple wrapper de apktool) para comprobar si existe un archivo llamado classes.dex, entonces lo extraes, y puedes convertir ese contenedor a formato Jar con la aplicación Dex2Jar: https://github.com/pxb1988/dex2jar/releases luego tienes que decompilar el archivo .Jar resultante, con DJ Java Decompiler o AndroChef Java Decompiler por ejemplo, entonces realizas las moificaciones que desees, reconstruyes el Jar con el mismo decompiler que usaste, reconstruyes el archivo dex con la otra aplicación, y por último reconstruyes el archivo APK con la aplicación que corresponda que ya mencioné al principio.

Ahora, puede darse el caso de que el archivo classes.dex no se encuentre en el interior del contenedor APK, de hecho eso parece ser lo más común, y entonces al parecer tienes que seguir los mismos pasos mencioandos, pero con un archivo que acabe en extensión ".odex"+

Pero hay otro problema, se puede dar el caso en que un contenedor APK no contenga ni un archivo classes.dex ni ningún archivo acabado en extensión ".odex", y ahí ya si que no se que hacer.

Saludos!
Realmente el formato .apk se puede descomprimir simplemente renombrando el archivo a .zip (es el mismo tipo de compresion)
Segun el compañero lo que has mencionado lo sabe hacer o eso a dicho en su primer comentario pero el problema es que quiere modificar una apk que no sabe en que lenguaje esta escrito (parece extraño que no este en java) pero como sigue sin dar la referencia de que apk es no sabemos aun el lenguaje que utiliza
Porfavor di exactamente la aplicacion que es, sino seguimos sin poder ayudarte.
Saludos
Pd: una explicacion muy completa la de obtencion del codigo fuente :)
Curso de ensamblador desde cero