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

中文一级a做爰片免费网站如何创建一个网站链接

中文一级a做爰片免费网站,如何创建一个网站链接,做网站十大公司哪家好,太原网站建设外包一、简介#xff1a; 在进行Android恶意APP检测时#xff0c;需要进行自动化的行为分析#xff0c;一般至少包括行为采集和行为分析两个模块。其中#xff0c;行为分析有基于规则、基于机器学习、基于深度学习甚至基于大模型的方案#xff0c;各有各的优缺点#xff0c;不…一、简介 在进行Android恶意APP检测时需要进行自动化的行为分析一般至少包括行为采集和行为分析两个模块。其中行为分析有基于规则、基于机器学习、基于深度学习甚至基于大模型的方案各有各的优缺点不是本文关注的重点本文主要关注Android APP的动态行为采集。在做Android APP逆向分析时经常需要通过hook系统调用观察APP的行为也需要一个动态行为追踪工具。 btraceGitHub - null-luo/btrace: btracebinder_transactioneBPFGolang实现通用的Android APP动态行为追踪工具就是一个开源的针对Android APP的动态行为采集/追踪工具。目标是通用、可靠、简单。如果类比到Linux tracing systems的话我们的工具也可以分成三部分data sources我们的方案是kprobe/binder_transactionway to extract data我们采用eBPFfrontends我们使用Golang。 接下来分别介绍这三个部分的方案。 二、data sourceskprobe/binder_transaction binder是Android IPC的核心机制Android APP在访问系统服务的时候实际上就是在进行跨进程通信因此监控binder就可以获取到APP调用系统服务的行为。 这里就不再重复说明了我们重点看一下在kernel层的哪个函数做监控比较好。我们的目标是要获取APP的包名、调用服务 首先想到的是内核已经定义的tracepoint  可惜大部分tracepoint都没有带上binder核心数据的指针也就是没有办法获取到目标服务名和函数参数   只有binder_ioctl这个tracepoint里面的arg指向的是struct binder_write_read 但问题是struct binder_write_read相当的原始解析起来比较复杂 这是因为binder_ioctl是链路上kernel层的第一个函数传进来的数据还没有经过处理。那么我们能不能找一找binder_ioctl后面的函数尽可能让系统对数据进行解析和处理之后我们直接拿到想要的字段呢 我们把binder_ioctl-binder_ioctl_write_read-binder_thread_write-binder_transaction这条调用链分析了一下发现binder_transaction是一个比较合适的点在它之前的函数已经对用户层传入的数据进行了很多解析和过滤这里拿到的数据是struct binder_transaction_data相对比较简单了 其实仔细看binder_transaction函数的代码可以发现本来通过binder_debug和trace_binder_transaction这两个地方直接拿到数据是最方便的可惜的是binder_debug没有输出code调用函数的编号trace_binder_transaction又没有输出调用服务名和参数的数据指针。导致没有办法直接使用这两个点。 尤其是trace_binder_transaction如果往后一点放到内存拷贝user-kernel完成之后再将数据指针输出的话就非常完美了。 所以最后我们还是回到对binder_transaction这个内核函数进行监控解析参数struct binder_transaction_data来拿到数据的方案。 三、way to extract dataeBPF eBPF是一个运行在Linux内核里面的虚拟机组件它可以在无需改变内核代码或者加载内核模块的情况下安全而又高效地拓展内核的功能。是一种非侵入性的内核函数hook方法。 并且Google 为了解决 Android 碎片化提出了GKI通用内核镜像要求Android 12以上版本的设备出厂必须使用GKI内核而且GKI内核的编译选项把eBPF相关的功能都是打开的。 所以eBPF特别适合用于对Android设备中Linux内核函数的监控。 binder_transaction函数总共5个参数我们可以根据第4个参数来过滤掉回应的transaction只关注请求的transaction 我们的目标是要获取APP的包名、调用服务名、调用函数名、调用参数这几个字段 APP的包名可以通过当前UID来获取因为binder_transaction函数是在client的进程内     调用函数名可以通过binder_transaction_data-code来获取     调用服务名和调用参数可以通过binder_transaction_data-data.ptr.buffer来获取 其中要注意的是binder_transaction_data-data.ptr.buffer指向的数据目前还在用户空间还没有完成向内核空间的拷贝所以需要使用bpf_probe_read_user函数。这就是我上节说的如果把trace_binder_transaction往后移到内存拷贝之后并且把内核空间的数据地址输出那就完美了可惜 四、frontendGolang eBPF的核心程序一般是使用C语言编写clang进行编译后需要将其加载到内核中。目前有多个项目对eBPF的编写调试运行的流程进行了封装和优化比如bcc、libbpf等我们选择的是cilium/ebpf。 它封装了BPF系统调用与内核提供的libbpf类似区别在于这个库是Go语言的更加方便进行用户态程序的开发而且外部依赖少与此同时其还提供了bpf2go工具可用来将eBPF程序编译成Go语言中的一部分使得交付更加方便。也就是说很容易将项目编译为一个独立可运行的ELF文件。 我们的开发环境是Ubuntu arm64的虚拟机主机是Mac cilium/ebpf使用起来非常方便整个框架分为三个部分 运行在内核态用C写eBPF代码llvm编译为eBPF字节码用户态使用Golang编写cilium/ebpf纯go类库做eBPF字节码的内核加载kprobe HOOK对应函数用户态使用Golang做事件读取、解码、处理。 我们在内核态程序里将需要的数据放到ringbuf里传递给用户态 用户态程序收到数据后做处理 1、APP的包名 知道UID后执行命令pm list packages -U去查一下就能知道 2、调用函数名、调用服务名、调用参数 Android进程间通信基于Proxy与Stub的设计模式AIDL是Android接口定义语言在写完AIDL文件后编译器自动生成一个同名的.java文件里面包含Stub和Proxy两个类Stub类是服务端抽象层的体现。Proxy的接口供客户端程序调用然后它内部会把信息包装好通过binder传递给Stub而后者通过对应的接口作用于服务端系统从而完成了“远程调用”。 先来看看Proxy的代码红色对应的就是要调用函数的编号也就是binder_transaction_data-code。蓝色就是要调用的服务的接口名绿色部分则是要调用函数的参数可以看出来这两部分被打包到一个Parcel里面去对应的就是binder_transaction_data-data.ptr。最后通过transact函数将以上三部分内容往binder传递。 writeInterfaceToken函数在写入接口名之前还写了12字节444的其他数据  我们在解析的时候先跳过头部12字节接下来的4字节代表接口名字符串的长度接着的数据即是接口名字符串  最后看一下binder_transaction_data-code如何转换成函数名仔细分析了binder流程代码函数名在编译.aidl文件的时候就已经转换成code了之后一直传递的都是code直到服务端的onTransact函数里才根据code去选择函数 所以在整个binder数据传输的过程中都找不到合适的hook点后来偶然发现.aidl文件自动生成的Stub类里面有getTransactionName、getDefaultTransactionName这么两个函数可以根据函数编码获取到函数名那么我们就可以使用反射来获取函数名  顺手在Android代码里搜索了一下这两个函数发现有一个类已经将对getDefaultTransactionName的调用包装好了  但是在golang里面不太好调用Android的API所以换了一个思路写了一个Android APP利用反射把系统服务下所有的transactionCode和methodName的映射关系记录下来输出给btrace在运行时候查询  有几个注意点 系统所有的服务名可以通过service list获取 需要打开策略开关才能访问hide的APIadb shell settings put global hidden_api_policy 1。 每一个服务内transaction函数一般是从1开始逐个编号的而且每个函数对应一个field所以我们获取服务类的field数目就知道此类最多有多少个transaction函数需要我们尝试去获取名字 最后效果参数的解析暂不支持  五、总结 我们使用binder_transactioneBPFGolang来实现一个针对Android APP的动态行为追踪工具目标是通用、可靠、简单。 通用基于binder底层内核函数可以监控到所有API调用覆盖系统版本广泛 可靠基于eBPF对内核无侵入并且有验证器的验证安全可靠 简单基于Golang作为frontend灵活高效逻辑简单清晰外部依赖少单一ELF可独立运行。
http://www.hkea.cn/news/14418273/

相关文章:

  • 佛山网站建设设计视频推广计划
  • 手机 网站开发aspx做网站的上香动画
  • 天津网络优化网站建设奖券世界推广网站
  • 实验室网站制作国外做贸易网站
  • 建个人网站一般多少钱小企业财务软件免费版
  • 怎么做百度采购网站苏州网站开发公司招聘信息
  • 海南智能网站建设报价5118站长网站
  • 网站网页制作的步骤是什么广州网站建设广州网络推广公司好
  • 郑州 网站建设网站备案登陆用户名是什么
  • 企业可以做哪些网站有哪些内容2022年必火的创业项目加盟
  • wordpress建立网站大型网站怎么加载图片的
  • 临海网站制作好了如何上线经典网络广告案例分析
  • 有没有免费建网站信息时代网站建设的重要性
  • cms建站系统开源都匀住房和城乡建设部网站
  • 全国电子网站建设wordpress标签页无效链接
  • 重庆孝爱之家网站建设wordpress去掉评论界面
  • 成都网站建设多少钱邯郸网站建设策划方案
  • 网站建设怎样创建链接安徽省建设安全监督站的网站
  • zhi做网站wordpress 微博时间
  • 盈利网站备案合肥做网站建设
  • 上海网站建设培训学校线上推广专员是干嘛的
  • 钢铁网站建设网络推广是什么职位
  • 网上购物网站建设论文贸易公司寮步网站建设
  • 简易博客网站模板下载做网站延期交付了
  • 电话销售网站建设话术网站制作+资讯
  • 营销类网站如何优化网站建设 媒体广告
  • 网站服务器建立杭州开发小程序公司
  • 什么是网站前台有哪些网站可以做青旅义工
  • 简单门户网站模板展厅设计概念方案
  • 网站备案 接电话wordpress编辑器 代码