Android沙盒开发之系统libc库定制修改

2013-07-29, 22:29:09  默认  【原创】Android沙盒开发之系统libc库定制修改
蟑螂一号 当前离线

标 题: 【原创】Android沙盒开发之系统libc库定制修改
作 者: 蟑螂一号
时 间: 2013-07-29,21:52:11
      android系统中libc是c层中最基本的函数库,libc中封装了io、文件、socket等基本系统调用。所有上层的调用都需要经过libc封装层。以Android4.2.2源码为例分析java socket的调用流程。
     Android4.2.2中,java层中的socket、bind、connect、send、recv、sendto、recvfrom等socket函数功能和C层socket的socket、bind、connect、send、recv、sendto、recvfrom等 是通过JNI方式实现java层socket到c层socket的调用。
   在源码目录libcore/luni/src/main/native/libcore_io_Posix.cpp中实现了java层socket功能的native函数。在该文件中,可以发现java层的socket发送和接收使用的是sendto和recvfrom函数,并没有使用系统调用send和recv。 n
   在源码目录bionic/libc/unistd目录下,可以看到send和recv系统调用实现是直接调用sendto和recvfrom。然而sendto和recvfrom函数实现文件并不好找。原来sendto和recvfrom是通过汇编代码实现,在汇编代码中通过swi调用中断号实现功能。那么如果我想把sendto或者recvfrom直接独立成c源文件该如何做?
   实现方法(以sendto为例):
   1.找到sendto.S文件,android4.2.2中文件路径bionic/libc/arch-arm/syscalls/目录下。
   2.将sendto.S改为__sendto.S并在汇编代码中将sendto改为__sendto.
   3.在bionic/libc/arch-arm/目录中修改后缀mk文件中的sento.S为__sendto.S。
   4.在bionic/libc/include/sys/socket.h中修改socketcall为前缀的sendto函数声明,将socketcall改为extern关键字。
   5.在bionic/libc/unistd中增加sendto.c文件,在文件中增加如下代码:
   #include <sys/types.h>
   #include <sys/socket.h>
   extern  ssize_t  __sendto(int,const void *,ssize_t ,unsinged int ,struct sockaddr*,socketlen_t);

  ssize_t    sendto(int fd,const void * buf,ssize_t len,unsinged int flags ,struct sockaddr* addr,socketlen_t slen) 
  { 
       return __sendto(fd,buf,len,flags,addr,slen);
   }
  6.修改bionic /libc目录中的android.mk文件,在该文件中找到send.c所在位置,并增加一行unistd/sendto.c。
    定制修改libc库作用:
  在android系统用户空间中libc是用户空间通向内核空间的一扇门。因此,能在此门设立关卡,就可以监控程序的各种数据流信息,对分析应用灰常有用。 
 
回复时引用此帖 返回顶端

malokch 的头像

普通会员
普通会员

资 料:
注册日期: Sep 2011
帖子:  156  malokch 品行端正
精华:  1
现金: 79 Kx
致谢数: 2
获感谢文章数:4
获会员感谢数:55
2  旧 2013-08-07, 14:50:03  默认
malokch 当前离线

年前我也想过开发一个沙盒软件,但是没有付诸实践。那时我是想用chroot来进行沙盒机制的实现的,但是想想在不修改源码的情况下修改ActivityManager挺困难,于是没有做。楼主可参考下chroot的实现。 
 
回复时引用此帖 返回顶端

蟑螂一号 的头像

普通会员
普通会员

资 料:
注册日期: May 2013
帖子:  77  蟑螂一号 品行端正
精华:  1
现金: 38 Kx
致谢数: 0
获感谢文章数:11
获会员感谢数:19
3  旧 2013-08-07, 15:34:40  默认
蟑螂一号 当前离线

引用:
最初由 malokch发布  查看帖子
年前我也想过开发一个沙盒软件,但是没有付诸实践。那时我是想用chroot来进行沙盒机制的实现的,但是想想在不修改源码的情况下修改ActivityManager挺困难,于是没有做。楼主可参考下chroot的实现。
非常感谢!希望多多交流!!! 
 
回复时引用此帖 返回顶端

malokch 的头像

普通会员
普通会员

资 料:
注册日期: Sep 2011
帖子:  156  malokch 品行端正
精华:  1
现金: 79 Kx
致谢数: 2
获感谢文章数:4
获会员感谢数:55
4  旧 2013-08-16, 07:54:02  默认
malokch 当前离线

如果不想大规模修改代码,最好的方法就是hook进城创建。安卓里做沙箱的话,因为每个app进程都是启动app_process,在app_process运行时加载app的dex和so等等。于是若想把进程隔离开,方案一是hook进城创建函数,使其转换为chroot过的进程来启动,达到隔离效果。方案二是自己做一个app_process,把原来的改名,由自己做的app_process启动原来的,然后再改父进程指向.
当然这些方法我都没试过,理论上可行,值得一试。以上仅做参考,且容易弄手机崩溃,这个后果自负了。 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值