成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何編寫YARA規(guī)則以改善安全和惡意軟件檢測?

譯文
安全 應(yīng)用安全
YARA不會取代防病毒軟件,但可以幫助您更有效地檢測問題,并允許更進(jìn)一步的定制。了解如何編寫YARA規(guī)則以改善安全和事件響應(yīng)。

[[440307]]

【51CTO.com快譯】本文介紹如何編寫YARA規(guī)則以充分利用它。

使用空模板開始入手

YARA規(guī)則是文本文件,遵循基本但強(qiáng)大的語法。

YARA規(guī)則包含三部分:

  • 元部分:這部分包含未處理但幫助用戶了解內(nèi)容的一般或特定的信息。
  • 字符串部分:這部分包含需要在文件中搜索的所有字符串。
  • 條件部分:這部分定義匹配的條件。它可以只匹配一個或多個字符串,但也可以較復(fù)雜,我們會在文章后面看到。

我強(qiáng)烈建議創(chuàng)建一個空模板,您將始終用它來開始編寫新規(guī)則。這樣,您只需填充幾個可變內(nèi)容,添加所需的條件。

  1. rule samplerule 
  2. meta: 
  3. author="Cedric Pernet" 
  4. version="0.1" 
  5. date="2021/05/12" 
  6. reference="any useful reference" 
  7. strings: 
  8. condition: 

使用該模板,您可以快速編輯元數(shù)據(jù)和規(guī)則名稱(本例中名為samplerule)。元數(shù)據(jù)可以是用戶想要放在那里的任何東西。我總是使用版本號、日期、可能是惡意軟件哈希的引用或提及我想要檢測的內(nèi)容的博客報(bào)告以及作者字段。

現(xiàn)在元數(shù)據(jù)已寫好,不妨開始編寫第一個規(guī)則。

第一個規(guī)則

YARA規(guī)則結(jié)合了字符串元素和條件。字符串可以是文本字符串、十六進(jìn)制字符串或正則表達(dá)式。

條件是布爾表達(dá)式,就像在其他編程語言中一樣。最有名的條件是AND、OR和NOT。 也可以使用關(guān)系、算術(shù)和按位運(yùn)算符。

這是第一個規(guī)則:

  1. rule netcat_detection 
  2. meta: 
  3. author="Cedric Pernet" 
  4. version="0.1" 
  5. date="2021/05/12" 
  6. reference="netcat is a free tool available freely online" 
  7. strings: 
  8. $str1="gethostpoop fuxored" // this is very specific to the netcat tool 
  9. $str2="nc -l -p port [options]" 
  10. condition: 
  11. $str1 or $str2 

不妨解釋這個名為netcat_detection的規(guī)則。

在我們通常的元數(shù)據(jù)之后,字符串部分包含兩個變量:str1和str2,當(dāng)然可以按我們的喜好來命名。此外為了說明如何添加注釋,第一個變量在末尾含有一個注釋。

條件部分包含以下條件:必須匹配str1或str2。

這可以用更舒適的方式來編寫:

  1. condition: 
  2.  
  3. any of ($str*) 

如果我們有很多不同的變量,只想匹配其中任何一個,這很有用。

運(yùn)行第一個規(guī)則

現(xiàn)在不妨運(yùn)行規(guī)則,我們將其保存為名為rule1.yar的文件。我們想針對包含多個不同文件的文件夾運(yùn)行它,其中兩個是netcat軟件的32位和64位版本(圖A)。我們用于測試的系統(tǒng)是Ubuntu Linux發(fā)行版,但這沒關(guān)系,因?yàn)閅ara可以輕松安裝在Linux、Mac或Windows操作系統(tǒng)上。

圖A. 在文件夾上運(yùn)行YARA規(guī)則以檢測特定軟件

不出所料,YARA運(yùn)行并返回匹配規(guī)則的所有文件的名稱。

當(dāng)然,您可以將任意數(shù)量的YARA規(guī)則放在一個文件中,這比擁有許多不同的規(guī)則文件更方便。

使用-s選項(xiàng)運(yùn)行YARA可顯示與這些文件匹配的確切字符串(圖 B):

圖B. 使用-s選項(xiàng)運(yùn)行YARA以顯示匹配的字符串

附帶說明一下,在公司網(wǎng)絡(luò)中的某個地方找到像netcat這樣的工具確實(shí)值得研究:普通用戶計(jì)算機(jī)上應(yīng)該找不到這個基本工具,因?yàn)樗试S計(jì)算機(jī)在特定端口上連接和交換數(shù)據(jù),可能被攻擊者所使用。當(dāng)然,它也可能被IT人員或紅隊(duì)人員使用,因此調(diào)查一番,以確定為什么在公司網(wǎng)絡(luò)的機(jī)器上發(fā)現(xiàn)它。

較復(fù)雜的字符串

匹配基本字符串足以在系統(tǒng)中查找文件。然而,字符串在不同系統(tǒng)上的編碼方式可能不同,或者可能被攻擊者輕微觸發(fā)。比如說,一個細(xì)微的變化可以改變使用隨機(jī)大小寫的字符串的大小寫。幸運(yùn)的是,YARA可以輕松處理這個問題。

在下面的YARA字符串部分,字符串無論使用什么大小寫都會匹配:

  1. strings: 
  2. $str1="thisisit" nocase 

條件$str1現(xiàn)在與使用的任何大小寫匹配:"ThisIsIt"、"THISISIT"、"thisisit"和"ThIsIsiT"等。

如果字符串使用每個字符兩個字節(jié)來編碼,可以使用“wide”修改符,當(dāng)然可以彼此結(jié)合。

  1. strings: 
  2. $str1="thisisit" nocase wide 

想搜索ASCII和寬格式的字符串,修改符“ascii”可與wide結(jié)合使用。

  1. strings: 
  2. $str1="thisisit" ascii wide 

十六進(jìn)制字符串

十六進(jìn)制字符串可輕松使用:

  1. strings: 
  2. $str1={ 75 72 65 6C 6E 20 } 
  3. $str2={ 75 72 65 6C ?? 20 } 
  4. $str3={ 75 72 [2-4] 65 6C } 

這是三個不同的十六進(jìn)制變量。第一個搜索十六進(jìn)制字符串上的精確序列。第二個使用兩個?字符表示的通配符,將搜索任何十六進(jìn)制值的帶有??的字符串。

第三個字符串搜索前兩個字節(jié),然后跳過兩到四個字符,最后是最后兩個字節(jié)。某些序列在不同文件中不一樣、但在兩個已知序列之間顯示可預(yù)測數(shù)量的隨機(jī)字節(jié)時(shí),這非常方便。

正則表達(dá)式

就像在任何編程語言中一樣,正則表達(dá)式對于檢測可以用不同方式編寫的特定內(nèi)容非常有用。在YARA中,它們通過使用以斜杠(/) 字符開頭和結(jié)尾的字符串來定義。

不妨舉一個有意義的例子。

在惡意軟件二進(jìn)制文件中,開發(fā)人員留下了調(diào)試信息,尤其是著名的PDB字符串。

內(nèi)容如下:

  1. D:\workspace\Malware_v42\Release\malw.pdb 

現(xiàn)在的想法是不僅要創(chuàng)建一個與該惡意軟件匹配的規(guī)則,還要創(chuàng)建它的所有不同版本,以防版本號發(fā)生變化。此外,我們決定從規(guī)則中排除“D”驅(qū)動器,因?yàn)殚_發(fā)人員也可能將它放在另一個驅(qū)動器上。

我們給出了正則表達(dá)式(圖C):

圖C. 根據(jù)其PDB字符串和結(jié)果,匹配惡意軟所有版本的規(guī)則

出于演示目的,我們構(gòu)建了一個名為newmalwareversion.exe的文件,包含三個不同的PDB字符串,每個字符串都有不同的版本號。我們的規(guī)則與它們?nèi)科ヅ洹?/p>

請注意,我們字符串中的\字符已加倍,因?yàn)閈是需要轉(zhuǎn)義的特殊字符,就像在C語言中一樣。

較復(fù)雜的條件

條件可能比僅匹配單個或多個字符串來得更智能。您可以使用條件來計(jì)算字符串、指定要查找字符串的偏移量、匹配文件大小甚至使用循環(huán)。

以下是我加注釋以解釋的幾個示例:

  1. condition: 
  2. of ($str*) // will match on 2 of several strings named str followed by a number 
  3. ($str1 or $str2) and ($text1 or $text2) // example of Boolean operators 
  4. #a == 4 and #b > 6 // string a needs to be found exactly four times and string b needs to be found strictly more than six times 
  5. $str at 100 // string str needs to be located within the file at offset 100 
  6. $str in (500..filesize) // string str needs to be located between offset 500 and end of file. 
  7. filesize > 500KB // Only files which are more than 500KB big will be considered 

原文標(biāo)題:How to write YARA rules for improving your security and malware detection,作者:Cedric Pernet

【51CTO譯稿,合作站點(diǎn)轉(zhuǎn)載請注明原文譯者和出處為51CTO.com】

 

責(zé)任編輯:華軒 來源: 51CTO
相關(guān)推薦

2013-10-29 15:17:41

2014-02-19 10:19:12

YARA惡意軟件

2022-07-05 08:41:28

Sigma日志事件開發(fā)

2023-08-15 08:32:09

yaraQA語法規(guī)則

2014-02-24 09:13:49

2019-03-26 09:11:32

無文件惡意軟件

2021-11-02 11:48:39

深度學(xué)習(xí)惡意軟件觀察

2011-05-16 09:30:59

2013-04-19 09:16:56

2021-11-18 14:01:25

網(wǎng)絡(luò)安全數(shù)據(jù)技術(shù)

2019-01-07 10:24:41

2021-03-19 10:40:37

勒索軟件物聯(lián)網(wǎng)威脅惡意軟件

2012-03-07 10:56:36

2014-03-13 09:28:34

2012-12-27 14:12:23

2013-11-20 09:47:40

2023-10-18 07:08:54

2014-09-17 15:22:57

2022-10-27 13:38:25

2012-11-19 13:25:21

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日本精品在线一区 | 久久99精品久久久久蜜桃tv | 91精品国产乱码久久久久久 | 婷婷午夜天 | 9久久婷婷国产综合精品性色 | av福利网站| 久久久免费观看视频 | 亚洲美女一区二区三区 | 日本三级电影免费观看 | 婷婷福利视频导航 | 日韩精品视频在线观看一区二区三区 | 高清亚洲 | 精品国产一区二区三区久久 | 在线观看亚洲一区二区 | 国产亚洲一级 | 亚洲欧美日韩中文字幕一区二区三区 | 免费三级网站 | 91免费小视频 | 成人在线精品视频 | 伊人网伊人网 | 精品视频一区二区 | 中文字幕精品视频 | 精品美女在线观看视频在线观看 | 日韩一区二区福利 | 国产精品99精品久久免费 | 国产真实精品久久二三区 | 免费在线观看黄网站 | 自拍视频在线观看 | 中文字幕 亚洲一区 | 日韩激情视频一区 | 天天干人人 | 欧美精品一区二区三区在线 | 中文字幕精品视频 | 成人不卡视频 | 97精品超碰一区二区三区 | 国产视频第一页 | 国产草草视频 | 中文字幕 亚洲一区 | 久久成人精品视频 | 日批日韩在线观看 | 国产成人精品区一区二区不卡 |