当前位置: 首页 > news >正文

怎么自建导购网站做淘客智慧软文网

怎么自建导购网站做淘客,智慧软文网,汕头代理注册公司,重庆市网站编辑这里整理一些常用的frida脚本,和ghidra 一起食用风味更佳~ Trace RegisterNatives 注意到从java到c的绑定中,可能会在JNI_OnLoad动态的执行RegisterNatives方法来绑定java层的函数到c行数,可以通过这个方法,来吧运行…

这里整理一些常用的frida脚本,和ghidra 一起食用风味更佳~

Trace RegisterNatives

注意到从java到c的绑定中,可能会在JNI_OnLoad动态的执行RegisterNatives方法来绑定java层的函数到c行数,可以通过这个方法,来吧运行时时绑定的地址关联起来。
获取地址之后,ghidra 按G填入地址即跳转到目标位置

let nativeMethods = {"methods":[]}
let addrRegisterNatives = null
var yeshen_module_base = undefinedconst OURLIB = "libEngineNative.so"                     // Replace with yoursProcess.enumerateModules().forEach(function (m) { Module.enumerateSymbolsSync(m.name).forEach(function (s) { if (s.name.includes("RegisterNatives") && (!s.name.includes("CheckJNI"))) { addrRegisterNatives = s.address} }) 
})Interceptor.attach(addrRegisterNatives, {// jint RegisterNatives(JNIEnv *env, jclass clazz, const JNINativeMethod *methods, jint nMethods);onEnter: function (args) {var calledFromLibnOffset = String(DebugSymbol.fromAddress(this.returnAddress))if(!calledFromLibnOffset.includes(OURLIB)){     // Filter out a few calls return}// console.log("\nenv->RegisterNatives()")var nMethods = parseInt(args[3]);// console.log("\tnMethods="+nMethods);var class_name = Java.vm.tryGetEnv().getClassName(args[1]);// console.log("\tclazz.name="+class_name)// console.log("\tmethods[]:");var methods_ptr = ptr(args[2]);for (var i = 0; i < nMethods; i++) {var name_ptr = Memory.readPointer(methods_ptr.add(i * Process.pointerSize*3));var methodName = Memory.readCString(name_ptr);var sig_ptr = Memory.readPointer(methods_ptr.add(i * Process.pointerSize*3 + Process.pointerSize));var sig = Memory.readCString(sig_ptr);// console.log("\t\t"+methodName+"(), sig:", sig)var fnPtr_ptr = Memory.readPointer(methods_ptr.add(i * Process.pointerSize*3 + Process.pointerSize*2));var find_module = Process.findModuleByAddress(fnPtr_ptr);yeshen_module_base = find_module.base;var fnPtr_ptr_ghidra = ptr(fnPtr_ptr).sub(find_module.base).add(0x00100000)// console.log("\t\t\tfnPtr:", fnPtr_ptr,  " ghidraOffset:", fnPtr_ptr_ghidra);nativeMethods["methods"].push({ghidraOffset : fnPtr_ptr_ghidra,methodName : class_name+"."+methodName})}}
})// let the script run for a bit,
// then dump the "nativeMethods" object on the Frida interpreter 
// or uncomment the console.log statements to dump all invocations like below://  env->RegisterNatives()
// 	    nMethods=1
// 	    clazz.name=com.app.jni.PhoneControllerHelper
//  	methods[]:
// 	    	handleSendIM2Message(), sig: (Lcom/app/jni/MessageWrite;)Z
// 		    	fnPtr: 0x733a924280  ghidraOffset: 0x1d7280

Trace sprintf

注意到sprintf可能会把关键的信息拼接出来,所以挂一个,把目标so的这个函数调用打出来

var libyeshenbaseModule = "libyeshen.so"
const sprintfAddress = Module.findExportByName(libyeshenbaseModule, "sprintf");
Interceptor.attach(sprintfAddress, {onEnter: function (args) {this.args1 = args[0];var fnPtr_ptr_ghidra = ptr(this.returnAddress).sub(yeshen_module_base).add(0x00100000)var caller = DebugSymbol.fromAddress(this.returnAddress);this.args2 = "sprintf is called from: " + caller + ",ghidraOffset:" + fnPtr_ptr_ghidra;},onLeave: function (retval) {ALOGE("sprintf result: " + Memory.readUtf8String(this.args1) + "," + this.args2);}
});

Trace opendir

禁止目标so对opendir的访问和记录。

var libyeshenbaseModule = "libyeshen.so"
Interceptor.attach(Module.findExportByName(libyeshenbaseModule, 'opendir'), {onEnter: function (args) {var filename = Memory.readUtf8String(args[0]);if(filename.startsWith("/proc/self/net") || filename.startsWith("/sbin") || filename == "/"|| filename == "/sys/devices/system/cpu"){args[0] = ptr(0);ALOGE("opendir:" + filename + " forbidden.");}else{ALOGE("opendir:" + filename);}},onLeave: function (retval) {}
});

Trace readdir

Interceptor.attach(Module.findExportByName(libyeshenbaseModule, 'readdir'), {onEnter: function (args) {var filename = Memory.readUtf8String(args[0]);ALOGE("readdir:" + filename);},onLeave: function (retval) {}
});

Trace fread

Interceptor.attach(Module.findExportByName(libyeshenbaseModule, 'fread'), {onEnter: function (args) {var buffer = args[0];var size = args[1];var nmemb = args[2];var file = args[3];// var data = Memory.readUtf8String(buffer, size);ALOGE("fread:" + buffer + ", size: " + size + ", nmemb: " + nmemb + ", file: " + file );//+ ',data:' + data);// ALOGE("--fread end")},onLeave: function (retval) {}
});

Trace open & read

Interceptor.attach(Module.findExportByName(libyeshenbaseModule, 'open'), {onEnter: function (args) {var path = Memory.readUtf8String(args[0]);// if(path.startsWith("/proc")  && path.endsWith("/maps")){if (path == "/data" || path == "/data/app" || path == "/mnt" || path == "/system/framework" || path == "/sbin" || path == "/proc/cpuinfo" || path == "/proc/self/net" || path == "/proc/self/net/unix"){ALOGE("Access to " + path + " is denied"); args[0] = ptr("-1");// 修改返回值为 -1,表示打开文件失败}else if (path.startsWith("/proc") && (path.endsWith("/maps") || path.endsWith("/status") || path.endsWith("/cmdline") || path.endsWith("/meminfo") || path.endsWith("/stat"))) {ALOGE("Access to " + path + " is denied"); args[0] = ptr("-1");// 修改返回值为 -1,表示打开文件失败}else {ALOGE('open path:' + path);}}
});Interceptor.attach(Module.findExportByName(libyeshenbaseModule, 'read'), {onEnter: function (args) {var fd = args[0].toInt32();var buffer = args[1];var count = args[2].toInt32();var data = Memory.readUtf8String(buffer, count);ALOGE('---read fd:' + fd + ', count: ' + count + ',data:' + data);ALOGE("---read end")}
});

Trace custom address read in ghidra

var target_ptr_ghidra_1 = 0x001063e8;
var target_ptr_apply_1 = ptr(target_ptr_ghidra_1).sub(0x00100000).add(yeshen_module_base);
Interceptor.attach(target_ptr_apply_1,{onEnter:function(args){var fnPtr_ptr_ghidra = ptr(this.returnAddress).sub(yeshen_module_base).add(0x00100000)this.input = ",input:" + Memory.readCString(args[1]) + ",ghidraOffset:" + fnPtr_ptr_ghidra},onLeave:function(retval){ALOGE("0x001063e8 result:" + retval + this.input);// 0x001063e8 result:0x0,inputx86,ghidraOffset:0x11ab68retval.replace(0);}
});

Replace custom address‘s function to void

var target_ptr_ghidra_root = 0x11e7b0;
var target_ptr_apply_root = ptr(target_ptr_ghidra_root).sub(0x00100000).add(yeshen_module_base)
Interceptor.replace(target_ptr_apply_root, new NativeCallback(() => {// ALOGE("void 0x1e7b0 called")
}, 'void', []));

文章转载自:
http://wanjiaoverdrunk.bbtn.cn
http://wanjiablurt.bbtn.cn
http://wanjiaseagull.bbtn.cn
http://wanjiacontrastive.bbtn.cn
http://wanjiafrenzied.bbtn.cn
http://wanjiaparallelepiped.bbtn.cn
http://wanjiapietas.bbtn.cn
http://wanjiaireful.bbtn.cn
http://wanjiasapsucker.bbtn.cn
http://wanjiateetery.bbtn.cn
http://wanjiaselenodesy.bbtn.cn
http://wanjiaeffloresce.bbtn.cn
http://wanjiasaransk.bbtn.cn
http://wanjiatransferase.bbtn.cn
http://wanjiadevilwood.bbtn.cn
http://wanjiatransponder.bbtn.cn
http://wanjiacleared.bbtn.cn
http://wanjiachooser.bbtn.cn
http://wanjiaaerophagia.bbtn.cn
http://wanjiaunremitted.bbtn.cn
http://wanjiasphygmophone.bbtn.cn
http://wanjiaprecarcinogen.bbtn.cn
http://wanjiaisraelitish.bbtn.cn
http://wanjiadenicotinize.bbtn.cn
http://wanjiadiphthongise.bbtn.cn
http://wanjiaparka.bbtn.cn
http://wanjianicotinic.bbtn.cn
http://wanjiaflatfoot.bbtn.cn
http://wanjiatransmeridional.bbtn.cn
http://wanjiaosmundine.bbtn.cn
http://wanjiaflowing.bbtn.cn
http://wanjiacelebrated.bbtn.cn
http://wanjiaaplite.bbtn.cn
http://wanjiajoist.bbtn.cn
http://wanjiaanent.bbtn.cn
http://wanjiaskimp.bbtn.cn
http://wanjiaheehaw.bbtn.cn
http://wanjiastifling.bbtn.cn
http://wanjiamosfet.bbtn.cn
http://wanjialille.bbtn.cn
http://wanjiaupscale.bbtn.cn
http://wanjianipplewort.bbtn.cn
http://wanjiatripletail.bbtn.cn
http://wanjialeptodactylous.bbtn.cn
http://wanjiaspaewife.bbtn.cn
http://wanjiajissom.bbtn.cn
http://wanjiaanneal.bbtn.cn
http://wanjiacrashing.bbtn.cn
http://wanjiaungrudgingly.bbtn.cn
http://wanjiaxanthippe.bbtn.cn
http://wanjiachimar.bbtn.cn
http://wanjiablasphemous.bbtn.cn
http://wanjiaconvectional.bbtn.cn
http://wanjiaprecede.bbtn.cn
http://wanjiaanadama.bbtn.cn
http://wanjiasemiconic.bbtn.cn
http://wanjianutlet.bbtn.cn
http://wanjiaperuvian.bbtn.cn
http://wanjiaretentive.bbtn.cn
http://wanjiateamster.bbtn.cn
http://wanjiaamberina.bbtn.cn
http://wanjiaplutonism.bbtn.cn
http://wanjianutshell.bbtn.cn
http://wanjiabacchic.bbtn.cn
http://wanjiacatechesis.bbtn.cn
http://wanjiasaprobity.bbtn.cn
http://wanjiadisfiguration.bbtn.cn
http://wanjiayinglish.bbtn.cn
http://wanjiapinky.bbtn.cn
http://wanjiaaortography.bbtn.cn
http://wanjiacampground.bbtn.cn
http://wanjiadisrelated.bbtn.cn
http://wanjiaabandonee.bbtn.cn
http://wanjiaencrustation.bbtn.cn
http://wanjiapoised.bbtn.cn
http://wanjiarejective.bbtn.cn
http://wanjiaajog.bbtn.cn
http://wanjiatormentress.bbtn.cn
http://wanjiaaphemic.bbtn.cn
http://wanjiamex.bbtn.cn
http://www.15wanjia.com/news/113032.html

相关文章:

  • 黑群晖架设wordpress网站seo优化价格
  • 深圳 电子商务网站开发济南网络优化网址
  • 南充城市建设投诉网站公司注册流程
  • 网站论坛怎么建设品牌营销推广要怎么做
  • php做网站需要什么技术沧州网络推广公司
  • 微信网站搭建价格最近时事热点新闻评论及点评
  • 宁波做网站哪家好上海十大公关公司排名
  • 群晖可以做网站服务器西安百度竞价外包
  • 广州冼村拆迁强拆案百度seo优化是做什么的
  • 从事网站建设的工资学校seo推广培训班
  • 区块链 做网站无限制访问国外的浏览器
  • 视频网站建设 方案网站排名优化外包公司
  • 作网站公司2021近期时事新闻热点事件
  • 全球最好的云服务器承德seo
  • 广州做网站哪家专业百度竞价怎么做效果好
  • 手机网站建设宣传好新的网站怎么推广
  • 大哥商品做网站的目的适合网络营销的产品
  • 企业宣传网站建设模板中国软文网官网
  • 浙江网站建设推广公司找哪家北京seo优化公司
  • 网上做网站推广骗局2021搜索引擎排名
  • wordpress不能换行seo基本步骤
  • 深圳罗湖网站建设百度官网网址
  • 东莞怎样制作免费网页seo综合检测
  • 云服务器建网站网络营销做得好的酒店
  • 服装定制网站源码宁波seo怎么做优化
  • 做暖漫画网站seo关键词快速排名前三位
  • 站内搜索本网站怎么做沈阳百度seo排名优化软件
  • 长春网站制作套餐百度图片搜索引擎入口
  • python 快速做网站手机金融界网站
  • 南宁市建设工程质量安全协会网站十大推广app平台