Compare commits

...

2 Commits

Author SHA1 Message Date
wangsiyuan 358c51a054 更新 main.py 2023-10-13 11:12:10 +08:00
wangsiyuan db7b6cb54a 更新 hook_conversions.js 2023-10-13 11:12:07 +08:00
2 changed files with 99 additions and 7 deletions

View File

@ -1,11 +1,101 @@
console.log("Script loaded successfully");
Java.perform(function() {
if (Java.available) {
Java.perform(function () {
console.log("start hook java.net.URL");
get_request_info()
var URL = Java.use('java.net.URL');
URL.$init.overload('java.lang.String').implementation = function(spec) {
if (spec.includes("appsflyer")){
URL.$init.overload('java.lang.String').implementation = function (spec) {
if (spec.includes("appsflyer")) {
console.log("URL request: " + spec);
if (spec.includes("conversions")){
// check_conversion_loaded()
var stackTrace = Java.use('java.lang.Exception').$new().getStackTrace().toString();
console.log(stackTrace);
}
}
return this.$init(spec);
};
// JSONObject.$init.overload('java.lang.String').implementation = function (jsonString) {
// var result = this.$init.overload('java.lang.String').call(this, jsonString);
// if (typeof result.toString !== "undefined") {
// console.log("result: " + result.toString())
// var msgData = jsonString.toString();
//
// if (msgData.contains("install_time") &&
// (msgData.contains("af_siteid") || msgData.contains("af_channel") ||
// msgData.contains("af_status") || msgData.contains("af_message")) &&
// (!msgData.contains("is_first_launch"))) {
// console.log("msgdata: " + msgData)
// }
// }
//
// return result;
// };
});
}
function check_conversion_loaded() {
Java.perform(function() {
var found = false;
Java.enumerateLoadedClasses({
onMatch: function(className) {
if (className.includes("AppsFlyer2dXConversionCallback")) {
console.log("Found: " + className);
found = true;
}
},
onComplete: function() {
if (!found) {
console.log("AppsFlyer2dXConversionCallback class not loaded.");
}
}
});
});
}
function get_request_info() {
console.log("start running get_request_info")
var HttpURLConnection = Java.use('java.net.HttpURLConnection');
var ByteArrayOutputStream = Java.use('java.io.ByteArrayOutputStream');
console.log(HttpURLConnection,ByteArrayOutputStream)
printMethods('java.net.HttpURLConnection');
printMethods('java.io.ByteArrayOutputStream');
HttpURLConnection.getRequestMethod.implementation = function () {
var url = this.getURL().toString();
var method = this.getRequestMethod();
console.log("URL: " + url + " | Request Method: " + method);
return method;
};
HttpURLConnection.setRequestProperty.implementation = function (key, value) {
if (this.getURL().toString().includes("conversions")){
console.log("Header: " + key + ": " + value);
}
return this.setRequestProperty(key, value);
};
HttpURLConnection.getOutputStream.implementation = function() {
var outputStream = this.getOutputStream();
var byteArrayOutputStream = ByteArrayOutputStream.$new();
var bytes = Java.array('byte', [1024]);
var len;
while ((len = outputStream.read(bytes)) != -1) {
byteArrayOutputStream.write(bytes, 0, len);
}
var requestBody = byteArrayOutputStream.toString();
if (this.getURL().toString().includes("conversions")) {
console.log("Request Body: " + requestBody);
}
return outputStream;
};
}
function printMethods(className) {
var jclass = Java.use(className);
var methods = jclass.class.getDeclaredMethods();
console.log("Printing methods of " + className + ":\n");
methods.forEach(function(method) {
console.log(method);
});
}

View File

@ -20,6 +20,7 @@ def attach_method(is_spawn):
def main(package_name,script_path,is_spawn):
print(f"script_path: {script_path}")
js_code = modules.files_utils.read_javascript(script_path)
# print(js_code)
modules.command.start_frida()
@ -59,4 +60,5 @@ if __name__ == '__main__':
attach_process_name = "Navi"
package_name = "com.naviapp"
script_path = "./hook_conversions.js"
# script_path = "./r0capture/script.js"
main(package_name,script_path, is_spawn)