2018年oakland论文:理解linux恶意软件

论文地址:http://www.s3.eurecom.fr/~yanick/publications/2018_oakland_linuxmalware.pdf

introduction

论文提出了linux而已软件长期没有被关注,尤其是学术界。

早期的几个linux下恶意软件的事件有VirusTotal,一些人的博客,以及对Mirai僵尸网络的一篇分析文章,在原文的引文234中。

这篇文章作为第一个全面分析linux下恶意软件的文章,对10548个linux下的恶意软件进行了长达一年的分析。这篇文章的贡献在于

1、记录了设计用来支持分析Linux恶意软件的几个工具的设计和实现,并讨论了处理这种特殊类型的恶意文件时所涉及的挑战

2、在一年内首次对10548个Linux恶意软件样本进行了大规模的实证研究。

3、揭示并讨论了现实世界中恶意软件使用的一些低层特定于linux的技术,并提供了当前使用情况的详细统计数据。

挑战

目标多样性:目的设备有很多种,比如智能电视,智能摄像头等待一些IOT设备。而这些设备分析起来都比较复杂

1、架构多样性:linux支持多种架构,所以要全面分析linux的恶意软件还需要做多种架构的支持

2、加载器和库:ELF允许自定义加载器和库,不同的环境使用的加载器和库不同,可能会直接造成程序不可执行

3、操作系统:由于ELF也是支持多种操作系统,很难区分开这写ELF是为那种系统编写的,因为其他系统中甚至连系统调用号否不一样

静态链接:会导致库函数被编译进可执行文件中,导致二进制分析变得很困难

分析环境:一些嵌入式设备上,恶意软件假定以管理员权限运行,而在分析恶意软件时,赋予而已软件root权限,则会赋予它更改沙箱的能力

缺乏相关工作:这是第一个全面分析恶意软件的工作,如何分析有很多的问题

分析流程

数据搜集:从VirusTotal获得样本

文件和元数据分析:直接分析ELF文件的格式等信息

静态分析:利用IDA分析加壳等信息

动态分析:kvm加qemu虚拟机运行,利用systemtap等共计收集运行时的一些信息

行为分析

1、ELF头操纵

文章指出而已软件经常通过更改ELF头

异常的ELF头,为什么需要更改这些信息

1、删除节信息:可以执行

2、更改可执行文件所在系统:报出提示但是还是可以执行

无效ELF

1、节表异常

2、重叠段

对用户程序的影响

IDA对异常ELF的处理最好,readelf、gdb等都不够好

2、持久性

子系统初始化:/stc/rcX.d下面这些脚本,rc.local脚本等,systemv intit的配置更改

cron进程:cron是Unix系统中基于时间的作业调度程序

文件替换和感染:替换掉关键地方的文件,感染关键文件

修改用户主目录中的配置文件:比如bashrc等

3、欺骗

使用一些特定的名字,比如正常软件的名字,或是每次执行都更改已从进程的名字

4、权限获取

隐藏自身痕迹:删除/var/log文件,删除/var/log/wtmp(包含登录信息)

系统漏洞提权

linux模块

5、打包和多态

UPX

自定义打包器

6、进程交互

多进程DDOS攻击

使用shell命令,实现持久性和删除历史等

进程注入,向运行进程注入代码来改变进程行为,或是窃取一些进程信息,3种方式实现进程跟踪

1、ptrace,子进程执行,执行ptrace,然后父进程也执行

2、ptrace加PID跟踪目标进程,然后向/proc/<target_pid>/mem中写值

3、执行process_vm_writev调用。process_vm_writev调用是2012年引入的一个新的系统调用,使用内核3.2在两个进程的地址空间之间直接传输数据。

7、信息获取

proc文件系统和sys文件系统

/etc目录下的配置文件

8、逃避

沙盒检测:搜集系统中的一些信息来看是不是有Wmware,qemu等信息

进程枚举:测试机器是否被感染,或是选择进程去杀死

ptrace反调试

拖延代码:只是用来进行网络通信

2018_oakland_linuxmalware的更多相关文章

随机推荐

  1. Flutter实战视频-移动电商-38.路由_Fluro中Handler编写方法

    38.路由_Fluro中Handler编写方法 在main.dart中初始化Fluro 编写handler 在lib下新建routers文件夹,表示里面要很多路由相关的文件 我们声明一个Handler ...

  2. Win10 VC++运行库集合|VC++ 2005 2008 2010 2012 2015

    在Win10系统中很多朋友在运行一些软件时会遇到缺少.DLL的情况,主要是没有安装VC++运行库下面小编收集了Win10 VC++运行库集合,大家安装上去就可以了~ 微软常用软件运行库合集(vc201 ...

  3. 无法打开包括文件:“SDKDDKVer.h”: No such file or directory

    在已经装有Visual Studio 2010的系统中,同时安装Visual Studio 2012,安装过程很顺利,但到使用VS2013时,却出问题了. 本文主要介绍:VS中新建工程编译时出现,“无 ...

  4. 骨骼动画反向动力学(IK)的实现

    反向动力学,Inverse Kinematics,简称IK.简单地说,由父骨骼的方位和子骨骼的相对变换得到子骨骼的方位,称为正向动力学(Forward Kinematics,FK):而IK则是先确定子 ...

  5. IT兄弟连 JavaWeb教程 JSP内置对象1

    JSP内置对象定义 JSP提供了由容器实现和管理的内置对象,也可以称之为隐含对象,这些内置对象不需要通过JSP页面编写来实例化,在所有的JSP页面中都可以直接使用,它们起到了简化页面的作用,JSP的内 ...

  6. 第二十篇 .NET高级技术之C#中的线程(二) 线程同步基础

    1.同步要领 下面的表格列展了.NET对协调或同步线程动作的可用的工具:                       简易阻止方法 构成 目的 Sleep 阻止给定的时间周期 Join 等待另一个线程 ...

  7. Spring pom.xml配置

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  8. SpringBoot | 启动异常 | 显示bulid success 无 error信息

    可能原因是没有添加 web 依赖,检查pom里面是否有web <dependency> <groupId>org.springframework.boot</groupI ...

  9. STP-4-每VLAN生成树和Trunk上的STP

    如果在有冗余链路且有多个VLAN的交换网络中只使用 STP实例,那么在稳定状态中,仍会有一些端口处于阻塞状态不被使用,冗余链路实际上变成了备份链路. PVST+特性能为每个VLAN创建一个STP实例. ...

  10. Storm编程入门API系列之Storm的Topology默认Workers、默认executors和默认tasks数目

    关于,storm的启动我这里不多说了. 见博客 storm的3节点集群详细启动步骤(非HA和HA)(图文详解) 建立stormDemo项目 Group Id :  zhouls.bigdata Art ...