欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Go構(gòu)建一款靜態(tài)分析工具Owl詳解

 更新時(shí)間:2022年06月10日 14:56:45   作者:LeonDing  
Owl是一款開源項(xiàng)目依賴分析工具,可以快速在指定的項(xiàng)目目錄下查找符合某些特征的源代碼文件或者依賴文件,這篇文章主要介紹了使用Go構(gòu)建一款靜態(tài)分析工具,需要的朋友可以參考下

介 紹

Owl是一款開源項(xiàng)目依賴分析工具,可以快速在指定的項(xiàng)目目錄下查找符合某些特征的源代碼文件或者依賴文件。為何開發(fā)了這款工具?例如很多時(shí)候我們項(xiàng)目太大,項(xiàng)目文件夾下有很多依賴文件,如一個(gè)Java項(xiàng)目引入了log4j這個(gè)jar依賴,在項(xiàng)目中某文件存在循環(huán)依賴問題。當(dāng)某個(gè)依賴包出現(xiàn)了漏洞時(shí),本工具能快速掃描項(xiàng)目目錄下存在的可疑依賴文件,并且給出依賴文件所在的地址,幫助開發(fā)者能快速進(jìn)行定位到可疑文件。

原 理

目前版本的功能比較簡單,工作原理很簡單,工具會(huì)對特定目錄進(jìn)行掃描通過內(nèi)置的特征碼算法匹配到特定文件,然后收集與其特征碼匹配的文件地址,然后展示出來,也可以重定向到一個(gè)固定json文件中保存。

Owl類似于殺毒軟件一樣,和殺毒軟件的工作原理差不多,Owl會(huì)根據(jù)依賴文件的特征碼來掃描整個(gè)項(xiàng)目,和殺毒病毒庫工作原理類似。當(dāng)然如果嚴(yán)格按照殺毒軟件那種標(biāo)準(zhǔn)做的話,可能涉及一些匯編相關(guān)的,目前owl功能實(shí)現(xiàn)還沒有那么復(fù)雜,后面會(huì)版本會(huì)加入codeql代碼分析引擎,通過codeql的數(shù)據(jù)庫來做靜態(tài)分析功能增強(qiáng)。

快速開始

如何使用owl?你可以克隆倉庫然后通過如下命令:

git clone git@github.com:auula/owl.git

在倉庫內(nèi)部有一個(gè)Makefile文件可以快速幫助你構(gòu)建相應(yīng)平臺的二進(jìn)制文件,例如:

$: make help
make darwin	| Compile executable binary for MacOS platform
make linux	| Compile executable binary for Linux platform
make windows	| Compile executable binary for Windows platform
make clean	| Clean up executable binary

Owl起因也是為CodeAnalysis所編寫的特征檢測工具,所以你也可以在:https://github.com/Tencent/CodeAnalysis 這個(gè)項(xiàng)目下面的tools目錄找到已經(jīng)編譯好的二進(jìn)制可執(zhí)行文件,下載對應(yīng)平臺的二進(jìn)制文件即可。

如何使用

程序構(gòu)建完成會(huì)得到一個(gè)二進(jìn)制文件,程序名稱為owl,如下為owl執(zhí)行效果,一些子命令參數(shù)都已經(jīng)列出:

$: ./owl
			 _____  _    _  __
			(  _  )( \/\/ )(  )
			 )(_)(  )    (  )(__
			(_____)(__/\__)(____) ?? v0.1.2
 A dependency module feature scanning detection tool for static analysis.

Usage:
  owl [command]
Available Commands:
  completion  Generate the autocompletion script for the specified shell
  help        Help about any command
  hex         File hex encoding
  md5         Collection file md5
  run         Execute the scanner
  version     Version information
Flags:
  -h, --help   help for owl
Use "owl [command] --help" for more information about a command.

如果不知道子命令如何使用,可以在對應(yīng)的子命令后面參入--help參數(shù),即可得到幫助信息:

例如如果你要查找log4j,你首先要通過owl計(jì)算log4j特征碼,命令如下:

$: ./owl md5 --path=/Users/ding/Downloads/log4j-1.2.17.jar

注意這里的特征碼計(jì)算必須使用owl程序的算法,因?yàn)?code>owl里面的算法針對大文件我是采用分?jǐn)?shù)據(jù)塊方案計(jì)算的,提升程序運(yùn)行速度,所以如果使用其他軟件的算法那么就會(huì)出現(xiàn)問題!

結(jié)果如下:

你也可以使用十六進(jìn)制字符串特征去查找:

$: ./owl hex --path=/Users/ding/Downloads/log4j-1.2.17.jar

程序會(huì)將對應(yīng)的文件轉(zhuǎn)成十六進(jìn)制字符串展示,如下圖:

現(xiàn)在就可以使用掃描器進(jìn)行掃描了,匹配模式可以指定為md5或者hex,未來可能會(huì)添加跟多的模式,命令如下:

$: ./owl run --dir=/Users/ding/Downloads/ --mode=md5 --code=04a41f0a068986f0f73485cf507c0f40

搜索得到具體依賴文件:

搜索結(jié)果如果過多,可以通過--out參數(shù)將結(jié)果重定向保存到文件中保存,文件格式為json!

SDK方式

上面介紹完是command line方式進(jìn)行的,owl程序本身就是一個(gè)command line,核心邏輯在 github.com/auula/owl/scan 這個(gè)包中編寫的,如果想二次開發(fā),那么就可以直接使用go get github.com/auula/owl 安裝這個(gè)模塊到你項(xiàng)目里面,然后直接通過硬編碼的方式進(jìn)行自定義編程;

一個(gè)簡單實(shí)例,通過自定義代碼方式進(jìn)行依賴文件掃描和收集:

package main
import (
    "fmt"
    "github.com/auula/owl/scan"
)
func main() {
    // 創(chuàng)建掃描器
    scanner := new(scan.Scanner)
    // 設(shè)置掃描器路徑     
    scanner.SetPath("github.com/auula/owl") 
    // 返回對應(yīng)路徑所有文件特征碼
    res, _ := scanner.List() 
    fmt.Println(res)
    // 設(shè)置指定的匹配器,其他匹配器查看API文檔
    scanner.SetMatcher(new(scan.Md5Matcher))
    // 搜索包含特征碼文件,返回文件記錄集合
    res, _ = scanner.Search("xxxx")
    // 打開一個(gè)文件描述符
    file, _ := os.OpenFile("res.json", os.O_CREATE|os.O_RDWR|os.O_TRUNC, 0666)
    // 將結(jié)果保存到指定文件中
    scanner.Output(file, res)
}

以上就是通過SDK方式自定義編碼完成依賴特征檢測。

其他

有問題歡迎提issue,工具不錯(cuò)的話記得按一個(gè)?,倉庫github.com/auula/owl。

到此這篇關(guān)于使用Go構(gòu)建一款靜態(tài)分析工具的文章就介紹到這了,更多相關(guān)Go靜態(tài)分析工具內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • golang語言中wasm 環(huán)境搭建的過程詳解

    golang語言中wasm 環(huán)境搭建的過程詳解

    將 golang 打包為 WASM,通常有兩種打包方式,一種是 golang 自帶的,另外是使用 tinygo ,接下來通過本文給大家介紹golang語言中wasm 環(huán)境搭建的過程,感興趣的朋友一起看看吧
    2021-11-11
  • 使用golang如何優(yōu)雅的關(guān)機(jī)或重啟操作示例

    使用golang如何優(yōu)雅的關(guān)機(jī)或重啟操作示例

    這篇文章主要為大家介紹了使用golang如何優(yōu)雅的關(guān)機(jī)或重啟操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • 利用Golang生成整數(shù)隨機(jī)數(shù)方法示例

    利用Golang生成整數(shù)隨機(jī)數(shù)方法示例

    這篇文章主要介紹了利用Golang生成整數(shù)隨機(jī)數(shù)的相關(guān)資料,文中給出了詳細(xì)的介紹和完整的示例代碼,相信對大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。
    2017-04-04
  • 簡單講解Go程序中使用MySQL的方法

    簡單講解Go程序中使用MySQL的方法

    這篇文章主要介紹了Go程序中使用MySQL的方法,需要使用第三方包來進(jìn)行連接,需要的朋友可以參考下
    2015-10-10
  • 一文帶你掌握Golang中的值類型和引用類型

    一文帶你掌握Golang中的值類型和引用類型

    在?Golang?中,數(shù)據(jù)類型可以分為兩大類:值類型(Value?Types)和引用類型(Reference?Types),理解這兩種類型的區(qū)別對于理解?Golang?中的數(shù)據(jù)傳遞和內(nèi)存管理是很重要的,下面就跟隨小編一起深入了解一下它們吧
    2024-01-01
  • golang中json的omitempty使用操作

    golang中json的omitempty使用操作

    這篇文章主要介紹了golang中json的omitempty使用操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Golang語言使用像JAVA?Spring注解一樣的DI和AOP依賴注入實(shí)例

    Golang語言使用像JAVA?Spring注解一樣的DI和AOP依賴注入實(shí)例

    這篇文章主要為大家介紹了Golang語言使用像JAVA?Spring注解一樣的DI和AOP依賴注入實(shí)例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 淺談Go語言的error類型

    淺談Go語言的error類型

    這篇文章主要介紹了淺談Go語言的error類型,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 總結(jié)Golang四種不同的參數(shù)配置方式

    總結(jié)Golang四種不同的參數(shù)配置方式

    這篇文章主要介紹了總結(jié)Golang四種不同的參數(shù)配置方式,文章圍繞主題展開詳細(xì)的內(nèi)容戒殺,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • Go實(shí)現(xiàn)文件分片上傳

    Go實(shí)現(xiàn)文件分片上傳

    這篇文章主要為大家詳細(xì)介紹了Go實(shí)現(xiàn)文件分片上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07

最新評論