真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

go語言嵌入式數(shù)據(jù)庫 go語言可做嵌入式開發(fā)嗎

go語言怎么連接oracle數(shù)據(jù)庫

//假設(shè)的GOPATH指向C:\gohome

目前創(chuàng)新互聯(lián)公司已為數(shù)千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、樺川網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

0. 執(zhí)行 go get github.com/wendal/go-oci8 ,然后肯定是報(bào)錯(cuò)了,沒關(guān)系,代碼會(huì)下載下來.

1. 首先,你需要安裝mingw到C:\mingw

2. 然后,到Oracle官網(wǎng),下載OCI及其SDK,解壓到instantclient_11_2 -- 當(dāng)前最新版

3. 從我的go-oci8庫的windows文件夾,拷貝pkg-config.exe到C:\mingw\bin\,拷貝oci8.pc到C:\mingw\lib\pkg-config\

4. 設(shè)置環(huán)境變量 PATH ,值為 原有PATH;C:\instantclient_11_2;C:\mingw\bin;

5. 設(shè)置環(huán)境變量 PKG_CONFIG_PATH,值為 C:\mingw\lib\pkg-config

6. 接下來,就最重要的,就是再執(zhí)行一次,這次應(yīng)該能成功的: go get github.com/wendal/go-oci8

7. 測試一下:

cd %GOPATH%/src/github.com/wendal/go-oci8/example

go run oracle.go

#提醒一句, oracle.go里面的寫的密碼是system/123456, 實(shí)例名XE

打造自己的滲透測試框架—溯光

TrackRay簡介

溯光,英文名“TrackRay”,意為逆光而行,追溯光源。同時(shí)致敬安全圈前輩開發(fā)的“溯雪”,“流光”。

溯光是一個(gè)開源的插件化滲透測試框架,框架自身實(shí)現(xiàn)了漏洞掃描功能,集成了知名安全工具:Metasploit、Nmap、Sqlmap、AWVS等。

溯光使用 Java 編寫,SpringBoot 作為基礎(chǔ)框架,JPA + HSQLDB嵌入式數(shù)據(jù)庫做持久化,Maven 管理依賴,Jython 實(shí)現(xiàn) Python 插件調(diào)用,quartz 做任務(wù)調(diào)度,freemarker + thymeleaf 做視圖層,Websocket 實(shí)現(xiàn)命令行式插件交互。

框架可擴(kuò)展性高,支持 Java、Python、JSON 等方式編寫插件,有“漏洞掃描插件”、“爬蟲插件”、“MVC插件”、“內(nèi)部插件”、“無交互插件”和“可交互插件” 等插件類型。

功能展示

主頁

登錄

任務(wù)創(chuàng)建

任務(wù)列表

任務(wù)詳情

無交互接口插件調(diào)用

MVC插件示例

交互式插件控制臺(tái)

MSF 控制臺(tái)

依賴環(huán)境

JDK 1.8

Python 2.7

Maven

Git

Metasploit

Nmap(建議安裝)

SQLMAP(建議安裝)

AWVS

**加粗為必須環(huán)境,沒有安裝程序則無法正常編譯運(yùn)行

不論是 Windows 還是 linux 一定需要先安裝 JDK1.8 和 Maven。安裝過程這里不做演示。保證 JDK 和 Maven 都在系統(tǒng)環(huán)境變量,能執(zhí)行java -version 和 mvn --version即可。

安裝過程

第一步

手動(dòng)啟動(dòng) AWVS 服務(wù)

登錄后臺(tái),生成一個(gè)API密匙。

復(fù)制密匙和 AWVS 的地址。

找到web/src/main/resources/application.properties配置文件。

修改如下部分

第二步

找到你 python 的第三方庫目錄。

Windows 的一般在 python 安裝目錄下的/Lib/site-packages

Linux 下可以通過輸出 sys.path 來找第三方包路徑

我的是 D:/Python2/Lib/site-packages

同樣找到web/src/main/resources/application.properties配置文件。

修改python.package.path參數(shù)

第三步

安裝 Maven 后找到倉庫位置。

如果沒有在 settings.xml 里配置指定倉庫目錄,默認(rèn)會(huì)在當(dāng)前用戶目錄中生成一個(gè) .m2的目錄

找到倉庫目錄后修改 application.properties 的 maven.repository.path參數(shù)

第四步

這個(gè)是 DNSLOG 回顯檢測漏洞時(shí)需要的。

去 ceye.io 注冊一個(gè)賬號(hào),拿到給你分配的域名和 TOKEN。

修改配置文件

第五步

啟動(dòng) msf 和 sqlmapapi。

如果你是 kali 操作系統(tǒng),可以直接運(yùn)行startdep.sh。

如果是其他系統(tǒng),則要找到 metasploit 和 sqlmap 的目錄分別執(zhí)行

啟動(dòng)成功后修改配置文件

第六步

編譯打包程序

等待依賴下載完成和編譯完成,如果以上操作都沒有出現(xiàn)問題則會(huì)提示 BUILD SUCCESS

編譯成功后會(huì)在當(dāng)前目錄打包一個(gè)trackray.jar就是溯光的主程序。

然后直接執(zhí)行startup.bat或startup.sh溯光就會(huì)啟動(dòng)服務(wù)。

沒有拋出異?;駿RROR日志,訪問 8080 端口正常。

服務(wù)啟動(dòng)正常后,登錄 iZone 社區(qū)賬號(hào)。

**開發(fā)插件建議使用 Intellij IDEA IDE,需要安裝 lombok 插件。

目錄結(jié)構(gòu)

插件

AbstractPlugin

這是交互式插件和非交互式插件的父類。

BASE常量

其中的靜態(tài)常量 BASE 是 /resources/include/ 的所在目錄。

如果你的插件需要額外的靜態(tài)資源,那么你可以在 /resources/include 目錄里創(chuàng)建一個(gè)和插件 KEY 相同的文件夾,便于識(shí)別,如果沒有在 @Plugin 注解中設(shè)置 value 則默認(rèn)的插件 KEY 就是當(dāng)前類名首字母小寫。

如 Typecho001 = typecho001

check(Map param)

這是用于檢驗(yàn)是否合規(guī)的方法,需要被強(qiáng)制重寫,當(dāng)返回 true 時(shí)才會(huì)調(diào)用 start() 方法

param 參數(shù)是從前臺(tái)傳過來的參數(shù)鍵值對。

常被用于檢驗(yàn)參數(shù)格式是否正確或漏洞是否存在。

after()

在 start() 方法之前調(diào)用

before()

在 start() 方法之后調(diào)用

start()

這是一個(gè)抽象方法,所有繼承了該類的子類都需要重寫這個(gè)方法。

在 check 方法 通過后會(huì)調(diào)用 start() 方法

start() 方法返回值最終會(huì)會(huì)當(dāng)做插件結(jié)果,響應(yīng)給前臺(tái)。

shell()

調(diào)用當(dāng)前系統(tǒng) shell 來輔助完成插件功能。

executor()

插件執(zhí)行的主方法

crawlerPage

http請求對象(不推薦使用)

fetcher

執(zhí)行 http 請求對象(不推薦使用)

errorMsg

當(dāng)校驗(yàn)不通過時(shí),返回給前臺(tái)的信息。

param

前臺(tái)傳過來的參數(shù)鍵值對

requests

HTTP 發(fā)包工具(推薦使用)

hackKit

hack 常用工具包

無交互插件

無交互插件需要你填寫好所有要填寫的參數(shù),直接請求接口來執(zhí)行插件。

默認(rèn)需要去繼承 CommonPlugin類。

這是一個(gè)抽象類,繼承了 AbstractPlugin

主要多出來兩個(gè)屬性:request 和 response。

繼承了 CommonPlugin 的類可以通過調(diào)用這兩個(gè)屬性來控制請求和響應(yīng)內(nèi)容。

無交互插件同時(shí)也需要使用 @Rule 和 @Plugin 插件,這兩個(gè)注解后面會(huì)講到。

在 ,找到相應(yīng)的插件填寫好參數(shù)提交即可完成調(diào)用。

或直接調(diào)用接口。

交互式插件

交互式插件一般在命令行控制臺(tái)中調(diào)用,可以允許你通過命令行交互來完成插件的調(diào)用。

交互式插件由 Websocket 實(shí)現(xiàn),想要寫一個(gè)交互式插件,首先要繼承 WebSocketPlugin 類。

同時(shí)設(shè)置 @Rule 注解的 websocket 參數(shù)為 true ,如果需要異步交互需要將 sync 也設(shè)置為 true。

內(nèi)部插件

內(nèi)部插件是不可以通過外部去調(diào)用的,需要繼承 InnerPlugin 并使用 @Plugin 注解,通常在漏洞掃描時(shí)時(shí)會(huì)調(diào)用。

例如 “網(wǎng)頁爬蟲”,“指紋識(shí)別”,“端口掃描” 等,都是通過調(diào)用內(nèi)部插件實(shí)現(xiàn)的。

還有用于檢測 SSRF 等漏洞用的 FuckCeye 插件也屬于內(nèi)部插件。

通過 spring 的自動(dòng)注入,來注入內(nèi)部插件到當(dāng)前對象。

例子可參考 WebLogicWLSRCE.java

爬蟲插件

爬蟲插件會(huì)在掃描任務(wù)被勾選“網(wǎng)頁爬蟲”時(shí)調(diào)用,每爬取一條請求就會(huì)調(diào)用一次爬蟲插件。

爬蟲插件需要繼承 CrawlerPlugin,繼承該類必須重寫 check 和 process 方法。

check 方法用于檢驗(yàn)請求是否符合插件規(guī)則,以免產(chǎn)生多余請求。

當(dāng) check 方法 返回為 true 時(shí)會(huì)調(diào)用 process 方法。

process 方法里寫插件主要檢測代碼。

addVulnerable()

當(dāng)插件檢測出漏洞時(shí),可以通過調(diào)用 addVulnerable() 方法來向數(shù)據(jù)庫插入一條漏洞。

requests

requests 屬性為請求工具包,處理 https 和 http 都很方便。

response

response 屬性為當(dāng)前爬蟲得到的 HTTP 響應(yīng)。

task

task 屬性為當(dāng)前任務(wù)對象,如果你的爬蟲插件不是檢測漏洞而希望是檢測一些敏感信息的話可以修改 task.getResult() 里的屬性。

參考 FingerProbe.java 或 InfoProbe.java。

target

爬蟲爬取到的 URL 對象。

fetcher crawlerPage

http 請求對象(不建議使用)。

漏洞掃描插件

漏洞掃描插件會(huì)在,掃描任務(wù)中勾選“漏洞攻擊模塊”時(shí)調(diào)用。

漏洞掃描插件分為三種

1.獨(dú)立插件

獨(dú)立的漏洞掃描插件需要繼承 AbstractExploit 并使用 @Plugin 或 @Exploit

AbstractExploit 中有以下需要了解的方法和屬性。

requests

http / https 發(fā)包工具

target 當(dāng)前掃描任務(wù)的地址。

task

當(dāng)前掃描任務(wù)對象。

check()

check 是一個(gè)抽象方法,需要被子類強(qiáng)制重寫。

該方法一般用于檢驗(yàn)是否符合當(dāng)前漏洞掃描插件的規(guī)則,以免產(chǎn)生多與請求。

attack()

attack 也是一個(gè)抽象方法,需要被子類強(qiáng)制重寫。

該方法是檢測漏洞的主方法。

before()

在 attack 方法前執(zhí)行

after()

在 attack 方法后執(zhí)行

addVulnerable()

當(dāng)插件檢測出漏洞時(shí),可以通過調(diào)用 addVulnerable() 方法來向數(shù)據(jù)庫插入一條漏洞。

fetcher crawlerPage

http 請求對象(不建議使用)。

2.漏洞規(guī)則

位于

實(shí)際上這是一個(gè)“內(nèi)部插件”,會(huì)在勾選漏洞模塊攻擊時(shí)調(diào)用。

有一些漏洞檢測方法很簡單,只通過簡單的判斷響應(yīng)體就能識(shí)別出來,也就沒有必要再去寫一個(gè)獨(dú)立的插件而占用空間了。

在 doSwitch() 方法中會(huì)先去根據(jù)當(dāng)前任務(wù)的指紋識(shí)別結(jié)果走一遍 switch 流程。

swtich 的每一個(gè) case 都是 WEB 指紋的枚舉對象。

當(dāng) switch 找到當(dāng)前任務(wù) WEB 指紋對應(yīng)的 case 后,case 內(nèi)的代碼會(huì)通過構(gòu)建一個(gè)漏洞規(guī)則添加到 loaders 集合里。

如果規(guī)則是通用的,可以寫在 switch 的外面。

3.kunpeng JSON插件

kunpeng 是一個(gè) go 語言編寫的 poc 測試框架,這里我對 kunpeng 的 JSON 插件做了一個(gè)支持。

只需要按照 kunpeng json 插件的格式規(guī)范創(chuàng)建一個(gè) json 文件到 /resources/json 目錄。

在掃描任務(wù)勾選“漏洞攻擊模塊”時(shí)會(huì)被調(diào)用,或通過 MVC 插件調(diào)用 。

MVC 插件

位于

MVC 插件的特點(diǎn)在于,他可以像是在寫一個(gè)功能一樣,而非簡單的接口式調(diào)用。

MVC 插件需要繼承 MVCPlugin 類,并使用 @Rule,@Plugin 注解。

MVCPlugin 內(nèi)置了一個(gè) ModelAndView 對象, 是 SpringMVC 提供的。

可以通過 setViewName() 來指定視圖層的網(wǎng)頁模板。

通過 addObject(key,value) 向視圖層網(wǎng)頁模板注入?yún)?shù)。

這里的視圖層是使用 thymeleaf 實(shí)現(xiàn)的,需要懂 thymeleaf 的語法。

例子可以參考:com.trackray.module.inner.JSONPlugin

繼承 MVCPlugin 必須要重寫一個(gè) index 方法,這是插件的入口。

如果需要寫其他的功能,就得再創(chuàng)建一個(gè) public 返回值為 void 的無參方法。

并且要在該方法上使用 @Function 注解,該注解的 value 參數(shù)如果不填寫的話則默認(rèn)的 requestMapping 地址為方法名。

例如

最后還需要在 /module/src/main/resources/templates 創(chuàng)建一個(gè)目錄名為插件 KEY 的目錄。

里面存放擴(kuò)展名為 .html 的模板文件。

Python 插件

python 插件有兩種實(shí)現(xiàn)方式。

1.通過命令行實(shí)現(xiàn)

這種方式最為簡單,通過在 include 里寫一個(gè) python 腳本。

然后在插件里調(diào)用 shell() 方法來執(zhí)行系統(tǒng)命令。

案例可參考 com.trackray.module.plugin.windows.smb.MS17010

但這樣還需要再寫 java 的代碼,對于沒有學(xué)過 java 的人來說很不友好。

2.通過jython實(shí)現(xiàn)

jython 是一個(gè) Python 語言在 Java 中的完全實(shí)現(xiàn)。

我將它的調(diào)用過程寫成了一個(gè)交互式插件。

你可以通過在 /resources/python/ 目錄下安裝如下規(guī)范去創(chuàng)建一個(gè) python 文件。

在這個(gè) python 文件中需要寫兩個(gè)方法。

關(guān)于注解

@Rule

一般用在“可交互插件”和“無交互插件”類上。

@Plugin

WEB指紋

這里順便再說一下如何添加指紋庫。

指紋庫位于 base 模塊,是一個(gè)枚舉類。

可以在首部或尾部添加一條新的枚舉,盡量使用 $ 開頭。

第一個(gè)參數(shù)是 指紋的名稱,如果第二個(gè)參數(shù)是 String 類型則是該指紋的說明。

FingerBean 類是指紋匹配對象。

go語言可以做什么

1、服務(wù)器編程:以前你如果使用C或者C++做的那些事情,用Go來做很合適,例如處理日志、數(shù)據(jù)打包、虛擬機(jī)處理、文件系統(tǒng)等。

2、分布式系統(tǒng)、數(shù)據(jù)庫代理器、中間件:例如Etcd。

3、網(wǎng)絡(luò)編程:這一塊目前應(yīng)用最廣,包括Web應(yīng)用、API應(yīng)用、下載應(yīng)用,而且Go內(nèi)置的net/http包基本上把我們平常用到的網(wǎng)絡(luò)功能都實(shí)現(xiàn)了。

4、開發(fā)云平臺(tái):目前國外很多云平臺(tái)在采用Go開發(fā),我們所熟知的七牛云、華為云等等都有使用Go進(jìn)行開發(fā)并且開源的成型的產(chǎn)品。

5、區(qū)塊鏈:目前有一種說法,技術(shù)從業(yè)人員把Go語言稱作為區(qū)塊鏈行業(yè)的開發(fā)語言。如果大家學(xué)習(xí)區(qū)塊鏈技術(shù)的話,就會(huì)發(fā)現(xiàn)現(xiàn)在有很多很多的區(qū)塊鏈的系統(tǒng)和應(yīng)用都是采用Go進(jìn)行開發(fā)的,比如ehtereum是目前知名度最大的公鏈,再比如fabric是目前最知名的聯(lián)盟鏈,兩者都有g(shù)o語言的版本,且go-ehtereum還是以太坊官方推薦的版本。

自1.0版發(fā)布以來,go語言引起了眾多開發(fā)者的關(guān)注,并得到了廣泛的應(yīng)用。go語言簡單、高效、并發(fā)的特點(diǎn)吸引了許多傳統(tǒng)的語言開發(fā)人員,其數(shù)量也在不斷增加。

使用 Go 語言開發(fā)的開源項(xiàng)目非常多。早期的 Go 語言開源項(xiàng)目只是通過 Go 語言與傳統(tǒng)項(xiàng)目進(jìn)行C語言庫綁定實(shí)現(xiàn),例如 Qt、Sqlite 等。

后期的很多項(xiàng)目都使用 Go 語言進(jìn)行重新原生實(shí)現(xiàn),這個(gè)過程相對于其他語言要簡單一些,這也促成了大量使用 Go 語言原生開發(fā)項(xiàng)目的出現(xiàn)。

(2). GO嵌入式開發(fā)之 --- 第一個(gè)GO程序

一、簡述GO語言背景

Wiki:

二、基本程序結(jié)構(gòu)

程序的各個(gè)部分:

三、應(yīng)用程序入口

四、退出返回值

五、獲取命令行參數(shù)


網(wǎng)頁題目:go語言嵌入式數(shù)據(jù)庫 go語言可做嵌入式開發(fā)嗎
當(dāng)前網(wǎng)址:http://weahome.cn/article/dopcopc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部