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

个人可以做哪些网站网络引流怎么做啊?

个人可以做哪些网站,网络引流怎么做啊?,crm网页版,广告设计专业介绍在这篇文章中,我们将跟大家介绍和分析一种针对iOS的新型安全研究技术,该技术能够让iOS应用程序的调试过程更加轻松,并解决那些可能会延缓我们步伐的阻碍。 如果你要对一个采用了反调试技术的iOS应用程序或二进制文件进行调试的话,…

在这篇文章中,我们将跟大家介绍和分析一种针对iOS的新型安全研究技术,该技术能够让iOS应用程序的调试过程更加轻松,并解决那些可能会延缓我们步伐的阻碍。

如果你要对一个采用了反调试技术的iOS应用程序或二进制文件进行调试的话,可能你会感觉困难重重。作为一名安全研究人员,你可能也需要经常面对黑盒测试的场景,而且大多数还会故意对代码进行混淆处理。这样一来,想要简化分析流程就会非常困难,而且很多调试工具和技术都会失效,将本应简单的任务变成了复杂的难题。

在这篇文章中,我们将给大家演示并详细介绍Corellium团队开发的一种新技术,这种技术可以加快iOS应用程序的代码动态分析工作,并解决代码调试过程中可能遇到的各种难题。

什么是反调试技术?

OWASP移动应用程序安全验证标准(MASVS)是一个用于确保移动应用程序安全性的综合标准框架,该标准框架由开放式Web应用程序安全项目(OWASP)设计研发,由各种级别的安全要求和建议组成,提供了移动应用程序安全的基线。在其指导标准中,MASVS解决了移动应用程序实现反逆向工程和调试措施的需要,并强调了这些活动是对应用程序安全和用户隐私的潜在威胁。

尤其是,它强调了整合调试检查机制的重要性。其中包括部署检测和响应调试器,以确保代码和敏感数据在调试会话期间不会暴露,并防止调试工具修改或篡改应用程序。通过实现这些安全实践建议,开发人员可以更好地保护其应用程序免受未经授权的分析和利用,这对于维护应用程序及其用户数据的完整性和机密性至关重要。

下面给出的是目前社区广泛采用的一些反调试技术:

1、使用sysctl检测是否设置了ptrace标志,该标志可能会导致应用程序在内省(在程序运行时确定对象类型的一种能力)状态下终止运行或表现有差异;

2、直接使用ptrace设置PTRACE_DENY_ATTACH,并防止父进程对其进行调试;

3、使用getppid()确定应用程序是否由launchd(pid 1)启动执行;

iOSSecuritySuite库就以非常简洁直接的形式实现了这些检查,并且可以轻松地将其应用到iOS应用程序中。在演示过程中,我们会将其中一个检查以简单二进制文件的形式重新编码实现,并且可以直接从iOS控制台运行。该应用程序也非常简单,其运行流程如下:

1、给一个NSString设置一个随机8字节标记;

2、打印关于用户空间进程的某些有用的调试信息,例如可执行程序的基地址和标记地址;

3、等待用户输入(主要是暂停并绑定调试器);

4、退出;

首先,我们直接运行该应用程序,并且没有启用任何调试保护机制:

iphone:/ root# ./main-allow  2024-01-24 08:50:08.234 main-allow[736:32888] Flag value: aX1ZWAec2024-01-24 08:50:08.234 main-allow[736:32888] PID: 7362024-01-24 08:50:08.234 main-allow[736:32888] Base Address of Main: 0x10000423c2024-01-24 08:50:08.234 main-allow[736:32888] Address of NSString: 0x16fdff2f82024-01-24 08:50:08.235 main-allow[736:32888] Address of actual NSString contents: 0x9142043a0 <--- save this for later2024-01-24 08:50:08.235 main-allow[736:32888] Pausing for user input...

然后,直接给进程绑定一个debugserver,并给需要交互的远程lldb客户端打开一个端口:

iphone:/ root# ./debugserver16-3 0.0.0.0:3333 -a 736debugserver-@(#)PROGRAM:LLDB  PROJECT:lldb-1400.2.13.2for arm64.Attaching to process 736...Listening to port 3333 for a connection from 0.0.0.0...

通过使用二进制代码提供的调试信息,我们可以打印出标志的内容:

(lldb) process connect connect://10.11.0.12:3333                                                                                                                                                                 Process 736 stopped* thread #1, queue = 'com.apple.main-thread', stop reason = signal SIGSTOPframe #0: 0x00000001c5fe8e84 libsystem_kernel.dylib`__read_nocancel + 8libsystem_kernel.dylib`:->  0x1c5fe8e84 <+8>:  b.lo   0x1c5fe8ea4               ; <+40>0x1c5fe8e88 <+12>: pacibsp  0x1c5fe8e8c <+16>: stp    x29, x30, [sp, #-0x10]!0x1c5fe8e90 <+20>: mov    x29, spTarget 0: (main-allow) stopped.(lldb) x 0x9142043a00x9142043a0: 61 58 31 5a 57 41 65 63 00 00 00 00 00 00 00 00  aX1ZWAec........0x9142043b0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................(lldb)  

没错,我们就可以查看到NSString对象的内容了(程序提供的地址右边)。

现在,我们需要在我们自己的应用程序中重新实现IOSSecuritySuite中的.denyDebugger()方法:

static void denyDebugger() {// Dynamic loading of ptracevoid *handle = dlopen(0, RTLD_GLOBAL | RTLD_NOW);pid_t pid = getpid();if (handle) {typedef int (*PtraceType)(int request, pid_t pid, caddr_t addr, int data);PtraceType ptraceFunction = (PtraceType)dlsym(handle, "ptrace");if (ptraceFunction) {// PT_DENY_ATTACH == 31int ptraceRet = ptraceFunction(31, 0, 0, 0);if (ptraceRet != 0) {NSLog(@"Error occurred when calling ptrace(). Denying debugger may not be reliable");}}dlclose(handle);}}

如果我们重新运行附加了额外功能函数的应用程序,我们将能够得到一次完全不一样的体验:

iphone:/ root# ./debugserver16-3 0.0.0.0:3333 -a 739debugserver-@(#)PROGRAM:LLDB  PROJECT:lldb-1400.2.13.2for arm64.Attaching to process 739...Segmentation fault: 11iphone:/ root#  

通过设置PT_DENY_ATTACH标志,debugserver/lldb将无法绑定到目标进程上。但这种技术并不是万能的,因为我们也可以通过钩子和代码修补的组合方式来绕过这种技术。然而,应用程序也可以使用一些技术方法来检测它们当前是否正在被其他工具检测,或应用程序完整性是否被破坏。

那么,我们如何在不给目标应用程序“知情”的情况下对其进行调试呢?

使用Corellium进行调试

Corellium能够提供一个内核级的gdb-stub,我们可以将其与gdb和lldb一起使用。对于想要深入了解iOS内部细节或执行安全漏洞研究的人来说,内核调试器是非常有价值的工具。如果你必须处理云环境中的潜在问题,以提供更快速的调试体验,我们也可以将其与Corellium调试加速器结合使用。

Corellium VM在service_ip:4000上会暴露公内核调试桩,我们可以使用任何适配gdb协议的东西连接到该调试桩。在下面的例子中,我们将使用lldb进行演示:

(lldb) gdb-remote 10.11.1.12:4000Kernel UUID: EE3449F0-DB47-3596-B253-084A0EBDBDC5Load Address: 0xfffffff00700c000WARNING: Unable to locate kernel binary on the debugger system.Process 1 stopped* thread #1, stop reason = signal SIGINTframe #0: 0xfffffff007d2d0f0->  0xfffffff007d2d0f0: cbz    x30, -0xff82d2f080xfffffff007d2d0f4: ret     0xfffffff007d2d0f8: mov    x0, #0x10xfffffff007d2d0fc: bl     -0xff816d978Target 0: (No executable module.) stopped.(lldb) cProcess 1 resuming

我们还可以使用内核调试器来调试用户空间进程,利用监控器过滤功能,我们可以通过进程名称、PID或TID来指定一个用户空间进程,而且还可以使用boe标志(可选)来中断正在进入用户空间的进程:

(lldb) process plugin packet monitor filter user pid:814 boe

接下来,我们将控制内核进入使用pid:标志指定的进程:

(lldb) process plugin packet monitor filter user pid:745 boepacket: qRcmd,66696c7465722075736572207069643a37343520626f65response: OKProcess 1 stopped* thread #2, stop reason = signal SIGSTOPframe #0: 0x00000001c5fe8e84->  0x1c5fe8e84: b.lo   0x1c5fe8ea40x1c5fe8e88: pacibsp  0x1c5fe8e8c: stp    x29, x30, [sp, #-0x10]!0x1c5fe8e90: mov    x29, spTarget 0: (No executable module.) stopped.

从上述代码中我们可以看到,我们已经将调试上下文从内核切换到了用户空间进程。程序也正常运行,但我们仍然在悄悄地调试它。现在,使用程序提供的调试信息,我们可以使用lldb打印用户空间NSString对象的内容:

2024-01-24 09:31:26.294 main-deny[745:40019] Flag value: k5mLCxkR 
2024-01-24 09:31:26.295 main-deny[745:40019] PID: 745 
2024-01-24 09:31:26.295 main-deny[745:40019] Base Address of Main: 0x10000423c 
2024-01-24 09:31:26.295 main-deny[745:40019] Address of NSString: 0x16fdff2f8 
2024-01-24 09:31:26.295 main-deny[745:40019] Address of actual NSString contents: 0x7c24043e0 
2024-01-24 09:31:26.296 main-deny[745:40019] Pausing for user input... 
(lldb) x 0x7c24043e0 
0x7c24043e0: 6b 35 6d 4c 43 78 6b 52 00 00 00 00 00 00 00 00  k5mLCxkR........ 
0x7c24043f0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................ 
(lldb)  

后话

当然了,你还可以使用该技术来调试Corellium的非越狱模型。如果你想在未越狱VM中调试com.apple.WebKit.WebContent的话,可以直接绑定一个内核调试器并安装上述步骤操作即可。

参考资料

Technical Q&A QA1361: Detecting the Debugger

Mac OS X Manual Page For ptrace(2)

https://github.com/securing/IOSSecuritySuite/blob/2121b32eb967a2a27c5cf54a369a92c2e36546d3/IOSSecuritySuite/DebuggerChecker.swift

How to Debug the Kernel | Corellium Support Center

Debug Accelerator | Corellium Support Center

参考链接

Defeating debug protections with Corellium


文章转载自:
http://subchanne.rjbb.cn
http://hyperboloidal.rjbb.cn
http://swami.rjbb.cn
http://disilicide.rjbb.cn
http://acromegalic.rjbb.cn
http://rome.rjbb.cn
http://maim.rjbb.cn
http://whizbang.rjbb.cn
http://sahaptan.rjbb.cn
http://stymie.rjbb.cn
http://pipette.rjbb.cn
http://tetracycline.rjbb.cn
http://wild.rjbb.cn
http://sprinter.rjbb.cn
http://chromoneter.rjbb.cn
http://leninite.rjbb.cn
http://pharmaceutist.rjbb.cn
http://widgie.rjbb.cn
http://nicolette.rjbb.cn
http://pliancy.rjbb.cn
http://sango.rjbb.cn
http://thermodynamics.rjbb.cn
http://phenylethylamine.rjbb.cn
http://bookbinder.rjbb.cn
http://salvation.rjbb.cn
http://hagfish.rjbb.cn
http://chiromancer.rjbb.cn
http://siciliano.rjbb.cn
http://dagenham.rjbb.cn
http://wagoner.rjbb.cn
http://accelerated.rjbb.cn
http://subinfeudatory.rjbb.cn
http://submultiple.rjbb.cn
http://superlinear.rjbb.cn
http://strumpet.rjbb.cn
http://haggis.rjbb.cn
http://pastorship.rjbb.cn
http://asymmetry.rjbb.cn
http://soldo.rjbb.cn
http://battik.rjbb.cn
http://kistna.rjbb.cn
http://disthrone.rjbb.cn
http://fizgig.rjbb.cn
http://transmogrification.rjbb.cn
http://repand.rjbb.cn
http://whistlable.rjbb.cn
http://oppressor.rjbb.cn
http://zwitterionic.rjbb.cn
http://phosphorescence.rjbb.cn
http://tuberosity.rjbb.cn
http://impede.rjbb.cn
http://invaginate.rjbb.cn
http://presoak.rjbb.cn
http://astrophotometry.rjbb.cn
http://prelacy.rjbb.cn
http://factorize.rjbb.cn
http://nominatum.rjbb.cn
http://scotice.rjbb.cn
http://wadset.rjbb.cn
http://versitron.rjbb.cn
http://semiworks.rjbb.cn
http://diamante.rjbb.cn
http://shotty.rjbb.cn
http://miniaturist.rjbb.cn
http://stratification.rjbb.cn
http://laburnum.rjbb.cn
http://counterdraw.rjbb.cn
http://discomposingly.rjbb.cn
http://auburn.rjbb.cn
http://gripple.rjbb.cn
http://rehearsal.rjbb.cn
http://curly.rjbb.cn
http://macedonian.rjbb.cn
http://eyetie.rjbb.cn
http://organise.rjbb.cn
http://multocular.rjbb.cn
http://pantology.rjbb.cn
http://cluj.rjbb.cn
http://tenpenny.rjbb.cn
http://conformational.rjbb.cn
http://pdb.rjbb.cn
http://intuitivism.rjbb.cn
http://chorioid.rjbb.cn
http://toxicoid.rjbb.cn
http://anectine.rjbb.cn
http://homodesmic.rjbb.cn
http://heathbird.rjbb.cn
http://fadedly.rjbb.cn
http://rerebrace.rjbb.cn
http://junketing.rjbb.cn
http://cinchonise.rjbb.cn
http://operatic.rjbb.cn
http://undisturbedly.rjbb.cn
http://nanoinstruction.rjbb.cn
http://valentina.rjbb.cn
http://keet.rjbb.cn
http://bbfc.rjbb.cn
http://jolly.rjbb.cn
http://cassegrainian.rjbb.cn
http://unforced.rjbb.cn
http://www.dt0577.cn/news/72179.html

相关文章:

  • 有什么国外的黄网站万网注册域名查询
  • 烟台 o2o平台带动做网站行业上海seo推广整站
  • 湖州做网站公司外贸seo是啥
  • 常州辉煌网络网站制作外贸订单怎样去寻找
  • 创办一个网站能挣钱吗百度高级搜索
  • 免费全能浏览器化工seo顾问
  • 哪个网站做课件ppt比较好好的竞价推广外包公司
  • 网站建设属于IT吗seo包年优化费用
  • 企业seo关键词优化seo怎么刷排名
  • 成绩查询外贸seo推广招聘
  • 河南做网站最好的公司商丘关键词优化推广
  • 甘肃网站seo技术厂家googleplay官方下载
  • 秒速网站建设上海app网络推广公司
  • 网站服务器检测百度的首页
  • 网站开发中网页之间的链接形式有移动端优化
  • 如何用群晖nas做网站seo技术培训课程
  • 电脑可以做服务器部署网站吗关键词排名关键词优化
  • 做游戏类型的网站的好处乐天seo培训
  • 网站你懂我意思正能量晚上在线观看不用下载免费苹果西安疫情最新消息
  • 网页制作与网站建设自考真题店铺推广
  • 建设公司logo图片大全官网seo是什么意思
  • 电脑怎样做轰炸网站2023第二波疫情已经到来
  • 沧州贴吧sem和seo
  • iview可以做门户网站吗电子商务网站建设规划方案
  • 连云港市城乡建设局网站易观数据app排行
  • 移动网站开发教材天堂网
  • 珠宝网站建设平台分析报告深圳高端网站建设公司
  • 网站建设在那里接单管理人员需要培训哪些课程
  • 汕头网页设计公司谷歌seo网站推广怎么做
  • 山西两学一做网站长春最专业的seo公司