浅析安全威胁情报共享框架OpenIOC

Outline:

1. Instruduction
2. IOC & OpenIOC
3. IOC Functionality
4. OpenIOC对行为的描述
5. IOCs in the Investigative Lifecycle
6. OpenIOC Tools

一、OpenIOC背景介绍

在当今的安全威胁环境下,为了应对更加复杂的攻击(如APT),如何便捷地分享、交流安全情报成为针对特定目标攻击检测、响应和防止的关键问题。传统地解决方案是先从主机或者网络中收集威胁情报信息,然后采用特定的技术规范描述,形成书面的报告分发共享给其它相关人员。这种做法最明显的问题是时间延迟非常高。因为即使在一个组织内部,情报共享的效率完全依赖于员工阅读和分发报告的能力,每次消息的传递都在增加安全事件的响应延迟。因此常见的情况是,当组织开始对事件响应时,所依据的信息往往已经过时,而且攻击早已在网络中蔓延造成了损失。

基于此,MANDIANT公司基于多年的数字取证技术的积累,将使用多年的情报规范开源后形成OpenIOC(Open Indicator of Compromise)框架,作为现实可用的安全情报共享规范。OpenIOC本身是一个记录、定义以及共享安全情报的格式,它可以帮助你借助机器可读的形式实现不同类型威胁情报的快速共享。OpenIOC本身是开放、灵活的框架,因此你随时可以根据发现添加新的情报,完善你的IOC(Indicator of Compromise)。

【关于MANDIANT】

该公司被众人所知是从其发布报告称中国RPC针对美国进行APT攻击开始。其具有以下几个特点:

1. MANDIANT创始人系特工出身:Kevin Mandia于2004年创立该公司,目的是帮助企业侦测、快速反应可能存在的网络入侵。Kevin有20年的信息安全从业经历,曾工作与五角大楼第七通信部任计算机安全官员,之后又加入了美国空军特别调查办公室(AFOSI);

2. MANDIANT公司开在中情局附近,而大多数安全公司都是扎堆在西海岸;

3. MANDIANT是获得FBI承认的“具备参与执法资格”的公司;

4. MANDIANT的业务主要是安全事件响应,现已被FireEye收购;

二、IOC与OpenIOC

IOC(Indicator of Compromise)是MANDIANT在长期的数字取证实践中定义的可以反映主机或网络行为的技术指示器;而OpenIOC是一套威胁情报共享的标准,通过遵循该标准,我们可以建立IOC的逻辑分组,实现威胁情报的交流共享,比如事件响应团队可以使用OpenIOC的规范编写多个IOCs来描述一个威胁的技术共性。

OpenIOC主要使用XML(Extensible Markup Language)来实现,XML语言提供了丰富、灵活的格式来将数据表示成可机读的形式。通常在使用OpenIOC时会定义自己的指示器属性表(Indicator Term Documens),里面列出了要使用的诸多属性,当然也可以根据自己的需要添加新的属性描述。

三、OpenIOC规范描述

OpenIOC通过XML来实现,每个IOC实质都是一个复合指示器,通常我们会将多个Indicator组合到一起作为一个IOC(Indicator of Compromise),最终在形式上IOC就是一个复合表达式,当表达式值为真时的,则该IOC命中(如作为攻击IOC,命中时表示该机器存在Compromise可能)。具体来说,我们需要明确一下几个术语:

表达式(Expression):定义了一个条件,当为真值时,表明存在一个入侵行为;

简单表达式(Simple Expression):没有使用AND或OR两种逻辑运算符的表达式;

复杂表达式(Complex Expression):多个简单表达式通过AND或OR连接;

攻击指示器(IOC):多个表达式的连接,可以是简单表达式、复杂表达式;

如图1-IOC Structure:

顶级逻辑为OR运算,下层的每个逻辑运算符AND或OR只作用于其子元素,如第一个AND运算只作用于Registry Path: version和Registry Text: 5, 1, 3802, 0;

我们通过图2和图3来说明IOC表达式的实际含义:

图2-Logic branch example:

每个表达式的条件有contains|contains not|is|is not四种;图2从文件名、大小、编译时间以及网络DNS和服务名、DLL等方面对行为进行了刻画。

图3-Indicator Expression:

 

上述IOC实际存储在一个XML文件中,类型名为ioc,IOC的XML标签并不多,刻画的细度主要通过设置不同的属性(IndicatoreItem)来实现,通过模块化的逻辑结构,可以随时根据获得的信息和知识进行IOC优化调整。IOC用到的基本XML标签如下:

< ioc>:用于标识一个IOC对象; < definition>:用于定义具体的Indicator: < Indicator>:用于包含多个IndicatorItem; < IndicatorItem>:用于描述一个具体的属性,其id值标识该属性,condition表明该表达式成立条件; < Context>:用于定义属性的大类和子类,标记属性名,如document="FileItem" search="FileItem/SizeInBytes", 最后的“mir”是MANDIANT Intelligence Response的缩写; < Content>:用于定义属性值的类型以及属性值,如type="int" ,大小为35343;

OpenIOC定义的XML标签主要就是以上几种,其对行为的刻画主要通过复杂丰富的IndicatorItem来体现,如图5所示:

四、OpenIOC对行为的刻画

OpenIOC对于行为的刻画主要依靠其IndicatorItem来实现,基于其在数字取证领域的多年实践,OpenIOC为我们提供了丰富、细化的行为描述属性。

OpenIOC一共提供了27类属性,分别是:

ArpEntryItem CookieHistoryItem DiskItem DnsEntryItem DriverItem Email EventLogItem FileDownloadHistoryItem FileItem FormHistoryItem HiveItem HookItem ModuleItem Network PortItem PrefetchItem ProcessItem RegistryItem SerivceItem Snort SystemInfoItem SystemRestoreItem TaskItem UrlHistoryItem UserItem VolumItem

针对上述每个大类,又可以细分出诸多小属性,比如以DiskItem为例,又细分为:

Disk Name Disk Partition Length Disk Partition Number Disk Partition Offset Disk Partition Type Disk Size

更多详细的属性说明在其官方文档中,除了列表中列出的属性,OpenIOC还支持自定义该格式的属性:

CommonIOCterms:http://openioc.org/terms/Common.iocterms

CurrentIOCterms:http://openioc.org/terms/Current.iocterms

五、IOC工作流程

MANDIANT主要在事件响应与数字取证领域使用IOCs,主要分为以下几个步骤:

获取初始证据:根据主机或网络的异常行为获取最初的数据;

建立主机或网络的IOCs:分析初步获得的数据,根据可能的技术特征建立IOCs;

在企业中部署IOCs:在企业的其它机器或网络中部署IOCs,开始检测;

发现更多的可疑主机;

IOCs优化:通过初步检测可获取的新证据,并进行分析,优化已有的IOCs;

六、OpenIOC工具

MANDIANT已经为OpenIOC开发了免费的使用工具,主要是IOCeditor和Redline两个工具。其中IOCeditor用来建立IOCs,而Redline负责将IOCs部署到HOST上收集信息后进行分析。主要过程如下:

运行Mandiant IOCe.exe,打开IOCeditor编辑器窗口,选择要编辑的IOC文件或新建IOC文件;

为现有的IOC添加IndicatorItem;

 

设定表达式条件;

 

设定AND或OR运算符;

保存成为.ioc文件;

接下来,需要将已经保存的.ioc文件生成collector部署到目标Host上,主要依靠Redline提供的IOCs部署功能:

首先运行Redline.exe选择“Create an IOC Search Collector”:

其次选择已经保存好的IOC文件,设定collector生成位置:

最后将生成的collector部署到目标机器上,运行脚本RunRedlineAudit.bat,完成后会在Sessions目录中保存收集的数据,可以在Redline中打开中进行分析;

七、小结

OpenIOC是一个开放灵活的安全情报共享框架,利用OpenIOC,重要的安全情报可以在多个组织间迅速传递,从而极大缩短检测到响应的时间延迟,提升紧急安全事件响应与安全防范的能力。但是由于其发展自数字取证领域,因此分析基本基于硬盘镜像的思想,即就系统的某一个时刻的状态进行分析

主要内容才考OpenIOC的官方文档:

AnIntroductiontoOpenIOC.pdf

IOCeUserGuide.pdf

ReadlinUserGuider.pdf

【资源列表】:

官方主页:http://openioc.org/

开源的IOCWriter:https://github.com/mandiant/ioc_writer

IOCEditor Tool下载:https://www.fireeye.com/services/freeware/ioc-editor.html

Redline下载:https://www.fireeye.com/services/freeware/redline.html

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/134688.html<

(0)
运维的头像运维
上一篇2025-03-01 06:47
下一篇 2025-03-01 06:48

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注