當前位置:首頁 » 網頁前端 » 滲透poc腳本使用
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

滲透poc腳本使用

發布時間: 2023-08-08 16:42:59

Ⅰ 滲透測試應該怎麼做呢

01、信息收集
1、域名、IP、埠
域名信息查詢:信息可用於後續滲透
IP信息查詢:確認域名對應IP,確認IP是否真實,確認通信是否正常
埠信息查詢:NMap掃描,確認開放埠
發現:一共開放兩個埠,80為web訪問埠,3389為windows遠程登陸埠,嘿嘿嘿,試一下
發現:是Windows Server 2003系統,OK,到此為止。
2、指紋識別
其實就是網站的信息。比如通過可以訪問的資源,如網站首頁,查看源代碼:
看看是否存在文件遍歷的漏洞(如圖片路徑,再通過…/遍歷文件)
是否使用了存在漏洞的框架(如果沒有現成的就自己挖)
02、漏洞掃描
1、主機掃描
Nessus
經典主機漏掃工具,看看有沒有CVE漏洞:
2、Web掃描
AWVS(Acunetix | Website Security Scanner)掃描器
PS:掃描器可能會對網站構成傷害,小心謹慎使用。
03、滲透測試
1、弱口令漏洞
漏洞描述
目標網站管理入口(或資料庫等組件的外部連接)使用了容易被猜測的簡單字元口令、或者是默認系統賬號口令。
滲透測試
① 如果不存在驗證碼,則直接使用相對應的弱口令字典使用burpsuite 進行爆破
② 如果存在驗證碼,則看驗證碼是否存在繞過、以及看驗證碼是否容易識別
風險評級:高風險
安全建議
① 默認口令以及修改口令都應保證復雜度,比如:大小寫字母與數字或特殊字元的組合,口令長度不小於8位等
② 定期檢查和更換網站管理口令
2、文件下載(目錄瀏覽)漏洞
漏洞描述
一些網站由於業務需求,可能提供文件查看或下載的功能,如果對用戶查看或下載的文件不做限制,則惡意用戶就能夠查看或下載任意的文件,可以是源代碼文件、敏感文件等。
滲透測試
① 查找可能存在文件包含的漏洞點,比如js,css等頁面代碼路徑
② 看看有沒有文件上傳訪問的功能
③ 採用…/來測試能否誇目錄訪問文件
風險評級:高風險
安全建議
① 採用白名單機制限制伺服器目錄的訪問,以及可以訪問的文件類型(小心被繞過)
② 過濾【./】等特殊字元
③ 採用文件流的訪問返回上傳文件(如用戶頭像),不要通過真實的網站路徑。
示例:tomcat,默認關閉路徑瀏覽的功能:
<param-name>listings</param-name>
<param-value>false</param-value>

3、任意文件上傳漏洞
漏洞描述
目標網站允許用戶向網站直接上傳文件,但未對所上傳文件的類型和內容進行嚴格的過濾。

滲透測試

① 收集網站信息,判斷使用的語言(PHP,ASP,JSP)
② 過濾規則繞過方法:文件上傳繞過技巧

風險評級:高風險

安全建議

① 對上傳文件做有效文件類型判斷,採用白名單控制的方法,開放只允許上傳的文件型式;

② 文件類型判斷,應對上傳文件的後綴、文件頭、圖片類的預覽圖等做檢測來判斷文件類型,同時注意重命名(Md5加密)上傳文件的文件名避免攻擊者利用WEB服務的缺陷構造畸形文件名實現攻擊目的;

③ 禁止上傳目錄有執行許可權;

④ 使用隨機數改寫文件名和文件路徑,使得用戶不能輕易訪問自己上傳的文件。

4、命令注入漏洞

漏洞描述

目標網站未對用戶輸入的字元進行特殊字元過濾或合法性校驗,允許用戶輸入特殊語句,導致各種調用系統命令的web應用,會被攻擊者通過命令拼接、繞過黑名單等方式,在服務端運行惡意的系統命令。

滲透測試

風險評級:高風險

安全建議

① 拒絕使用拼接語句的方式進行參數傳遞;

② 盡量使用白名單的方式(首選方式);

③ 過濾危險方法、特殊字元,如:【|】【&】【;】【』】【"】等

5、sql注入漏洞

漏洞描述

目標網站未對用戶輸入的字元進行特殊字元過濾或合法性校驗,允許用戶輸入特殊語句查詢後台資料庫相關信息

滲透測試

① 手動測試:判斷是否存在SQL注入,判斷是字元型還是數字型,是否需要盲注

② 工具測試:使用sqlmap等工具進行輔助測試

風險評級:高風險

安全建議

① 防範SQL注入攻擊的最佳方式就是將查詢的邏輯與其數據分隔,如Java的預處理,PHP的PDO

② 拒絕使用拼接SQL的方式

6、跨站腳本漏洞

漏洞描述

當應用程序的網頁中包含不受信任的、未經恰當驗證或轉義的數據時,或者使用可以創建 HTML或JavaScript 的瀏覽器 API 更新現有的網頁時,就會出現 XSS 缺陷。XSS 讓攻擊者能夠在受害者的瀏覽器中執行腳本,並劫持用戶會話、破壞網站或將用戶重定向到惡意站點。

三種XSS漏洞:

存儲型:用戶輸入的信息被持久化,並能夠在頁面顯示的功能,都可能存在存儲型XSS,例如用戶留言、個人信息修改等。

② 反射型:URL參數需要在頁面顯示的功能都可能存在反射型跨站腳本攻擊,例如站內搜索、查詢功能。

③ DOM型:涉及DOM對象的頁面程序,包括:document.URL、document.location、document.referrer、window.location等

滲透測試

存儲型,反射型,DOM型

風險評級:高風險

安全建議

① 不信任用戶提交的任何內容,對用戶輸入的內容,在後台都需要進行長度檢查,並且對【<】【>】【"】【』】【&】等字元做過濾
② 任何內容返回到頁面顯示之前都必須加以html編碼,即將【<】【>】【"】【』】【&】進行轉義。

7、跨站請求偽造漏洞

漏洞描述

CSRF,全稱為Cross-Site Request Forgery,跨站請求偽造,是一種網路攻擊方式,它可以在用戶毫不知情的情況下,以用戶的名義偽造請求發送給被攻擊站點,從而在未授權的情況下進行許可權保護內的操作,如修改密碼,轉賬等。

滲透測試

風險評級:中風險(如果相關業務極其重要,則為高風險)

安全建議

① 使用一次性令牌:用戶登錄後產生隨機token並賦值給頁面中的某個Hidden標簽,提交表單時候,同時提交這個Hidden標簽並驗證,驗證後重新產生新的token,並賦值給hidden標簽;

② 適當場景添加驗證碼輸入:每次的用戶提交都需要用戶在表單中填寫一個圖片上的隨機字元串;

③ 請求頭Referer效驗,url請求是否前部匹配Http(s)😕/ServerHost

④ 關鍵信息輸入確認提交信息的用戶身份是否合法,比如修改密碼一定要提供原密碼輸入

⑤ 用戶自身可以通過在瀏覽其它站點前登出站點或者在瀏覽器會話結束後清理瀏覽器的cookie;

8、內部後台地址暴露

漏洞描述

一些僅被內部訪問的地址,對外部暴露了,如:管理員登陸頁面;系統監控頁面;API介面描述頁面等,這些會導致信息泄露,後台登陸等地址還可能被爆破。

滲透測試

① 通過常用的地址進行探測,如login.html,manager.html,api.html等;

② 可以借用burpsuite和常規頁面地址字典,進行掃描探測

風險評級:中風險

安全建議

① 禁止外網訪問後台地址

② 使用非常規路徑(如對md5加密)

9、信息泄露漏洞

漏洞描述

① 備份信息泄露:目標網站未及時刪除編輯器或者人員在編輯文件時,產生的臨時文件,或者相關備份信息未及時刪除導致信息泄露。

② 測試頁面信息泄露:測試界面未及時刪除,導致測試界面暴露,被他人訪問。

③ 源碼信息泄露:目標網站文件訪問控制設置不當,WEB伺服器開啟源碼下載功能,允許用戶訪問網站源碼。

④ 錯誤信息泄露:目標網站WEB程序和伺服器未屏蔽錯誤信息回顯,頁面含有CGI處理錯誤的代碼級別的詳細信息,例如SQL語句執行錯誤原因,PHP的錯誤行數等。

⑤ 介面信息泄露:目標網站介面訪問控制不嚴,導致網站內部敏感信息泄露。

滲透測試

① 備份信息泄露、測試頁面信息泄露、源碼信息泄露,測試方法:使用字典,爆破相關目錄,看是否存在相關敏感文件

② 錯誤信息泄露,測試方法:發送畸形的數據報文、非正常的報文進行探測,看是否對錯誤參數處理妥當。

③ 介面信息泄露漏洞,測試方法:使用爬蟲或者掃描器爬取獲取介面相關信息,看目標網站對介面許可權是否合理

風險評級:一般為中風險,如果源碼大量泄漏或大量客戶敏感信息泄露。

安全建議

① 備份信息泄露漏洞:刪除相關備份信息,做好許可權控制

② 測試頁面信息泄露漏洞:刪除相關測試界面,做好許可權控制

③ 源碼信息泄露漏洞:做好許可權控制

④ 錯誤信息泄露漏洞:將錯誤信息對用戶透明化,在CGI處理錯誤後可以返回友好的提示語以及返回碼。但是不可以提示用戶出錯的代碼級別的詳細原因

⑤ 介面信息泄露漏洞:對介面訪問許可權嚴格控制

10、失效的身份認證

漏洞描述

通常,通過錯誤使用應用程序的身份認證和會話管理功能,攻擊者能夠破譯密碼、密鑰或會話令牌, 或者利用其它開發缺陷來暫時性或永久性冒充其他用戶的身份。

滲透測試

① 在登陸前後觀察,前端提交信息中,隨機變化的數據,總有與當前已登陸用戶進行綁定的會話唯一標識,常見如cookie

② 一般現在網站沒有那種簡單可破解的標識,但是如果是跨站認證,單點登錄場景中,可能為了開發方便而簡化了身份認證

風險評級:高風險

安全建議

① 使用強身份識別,不使用簡單弱加密方式進行身份識別;

② 伺服器端使用安全的會話管理器,在登錄後生成高度復雜的新隨機會話ID。會話ID不能在URL中,可以安全地存儲,在登出、閑置超時後使其失效。

11、失效的訪問控制

漏洞描述

未對通過身份驗證的用戶實施恰當的訪問控制。攻擊者可以利用這些缺陷訪問未經授權的功能或數據,例如:訪問其他用戶的帳戶、查看敏感文件、修改其他用戶的數據、更改訪問許可權等。

滲透測試

① 登入後,通過burpsuite 抓取相關url 鏈接,獲取到url 鏈接之後,在另一個瀏覽器打開相關鏈接,看能夠通過另一個未登入的瀏覽器直接訪問該功能點。

② 使用A用戶登陸,然後在另一個瀏覽器使用B用戶登陸,使用B訪問A獨有的功能,看能否訪問。

風險評級:高風險

安全建議

① 除公有資源外,默認情況下拒絕訪問非本人所有的私有資源;

② 對API和控制器的訪問進行速率限制,以最大限度地降低自動化攻擊工具的危害;

③ 當用戶注銷後,伺服器上的Cookie,JWT等令牌應失效;

④ 對每一個業務請求,都進行許可權校驗。

12、安全配置錯誤

漏洞描述

應用程序缺少適當的安全加固,或者雲服務的許可權配置錯誤。

① 應用程序啟用或安裝了不必要的功能(例如:不必要的埠、服務、網頁、帳戶或許可權)。

② 默認帳戶的密碼仍然可用且沒有更改。

③ 錯誤處理機制向用戶披露堆棧跟蹤或其他大量錯誤信息。

④ 對於更新的系統,禁用或不安全地配置最新的安全功能。

⑤ 應用程序伺服器、應用程序框架(如:Struts、Spring、ASP.NET)、庫文件、資料庫等沒有進行相關安全配置。

滲透測試

先對應用指紋等進行信息搜集,然後針對搜集的信息,看相關應用默認配置是否有更改,是否有加固過;埠開放情況,是否開放了多餘的埠;

風險評級:中風險

安全建議

搭建最小化平台,該平台不包含任何不必要的功能、組件、文檔和示例。移除或不安裝不適用的功能和框架。在所有環境中按照標準的加固流程進行正確安全配置。

13、使用含有已知漏洞的組件

漏洞描述

使用了不再支持或者過時的組件。這包括:OS、Web伺服器、應用程序伺服器、資料庫管理系統(DBMS)、應用程序、API和所有的組件、運行環境和庫。

滲透測試

① 根據前期信息搜集的信息,查看相關組件的版本,看是否使用了不在支持或者過時的組件。一般來說,信息搜集,可通過http返回頭、相關錯誤信息、應用指紋、埠探測(Nmap)等手段搜集。

② Nmap等工具也可以用於獲取操作系統版本信息

③ 通過CVE,CNVD等平台可以獲取當前組件版本是否存在漏洞

風險評級:按照存在漏洞的組件的安全風險值判定當前風險。

安全建議

① 移除不使用的依賴、不需要的功能、組件、文件和文檔;

② 僅從官方渠道安全的獲取組件(盡量保證是最新版本),並使用簽名機制來降低組件被篡改或加入惡意漏洞的風險;

③ 監控那些不再維護或者不發布安全補丁的庫和組件。如果不能打補丁,可以考慮部署虛擬補丁來監控、檢測或保護。
詳細學習可參考:

Ⅱ 滲透測試七個步驟

滲透測試七個步驟如下:

步驟一:明確目標

1、確定范圍:規劃測試目標的范圍,以至於不會出現越界的情況。

2、確定規則:明確說明滲透測試的程度、時間等。

3、確定需求:滲透測試的方向是web應用的漏洞?業務邏輯漏洞?人員許可權管理漏洞?還是其他,以免出現越界測試。

步驟二:信息收集

1、基礎信息:IP、網段、域名、埠

2、系統信息:操作系統版本

3、應用信息:各埠的應用,例如web應用、郵件應用等等

4、版本信息:所有哪數探測到的東西的版本

5、人員信息:域名注冊人員信息,web應用中網站發帖人的id、管理員姓名等

6、防護信息:試著看能否探測到防護的設備,像有沒有CDN、waf等

步驟三:漏洞探索

利用上一步中列出的各種系統、應用等等,使用響應的漏洞

方法:

1、漏掃、awvs、IBM appscan等

2、結合漏洞去exploit-db等位置找利用

3、在網上尋找驗證poc

步驟四:漏洞驗證

將上述中發現有可能可以成功利用的全部漏洞都驗證一遍,結合實際情況搭建模擬環境進行實驗,成功後再引用於目標。

自動化驗證:結合自動化掃描工具提供的結果

手工驗證:根據公開的資源進行手工驗證

試驗驗證:自己搭建模擬環境進行驗證

登錄猜解:可以嘗試一下登錄口的賬號密碼的發現

業務邏輯漏洞:如發現業務邏輯漏洞,進行驗證

步驟五:信息分析

為下一步實施滲透做准備

1、精準打擊:准備好上一步探測到的漏洞的exp,顫拆用來精準打擊

2、繞過防禦機制:是否有防火牆等設備,如何繞過

3、定製攻擊路徑:最佳工具路徑,根據薄弱入口,高內網許可權位置,最終目標

4、繞過檢測機制:是否有檢測機制,流量監控,殺毒軟體 ,惡意代碼檢測等(免殺)

5、攻擊代碼:經過試驗得來的代碼,包括不限於XSS代碼,SQL注入語句等

步驟六:獲取所需

1、實施攻擊,根據前幾步的結果,李洞首進行攻擊

2、獲取內部信息:基礎設施(網路連接,vpn,路由,拓撲等)

3、進一步滲透:內網入侵,敏感目標

4、持續性存在:一般我們對客戶做滲透不需要,但真實的環境中,我們會做rookit、後門,添加管理賬號。駐扎手法。

5、清理痕跡:清理相關日誌(訪問,操作),上傳文件等

步驟七:信息整理、形成報告

1、整理滲透工具:整理滲透過程中用到的代碼,poc、exp等

2、整理收集信息:整理滲透過程中收集到的一切信息

3、整理漏洞信息:整理滲透過程中遇到的各種漏洞,各種脆弱的位置信息(為了形成報告,形成測試結果使用)

4、按需整理:按照之前第一步跟客戶確定好的范圍和需求來整理資料,並將資料形成報告

5、補充介紹:要對漏洞成因、驗證過程和帶來的危害進行分析

6、修補建議:當然要對所有產生的問題提出合理高效安全的解決辦法

Ⅲ 學習滲透測試,需要哪些基礎

滲透測試需要的基礎技能必須有網路基礎、編程基礎、資料庫基礎、操作系統等基本技能。學習的話可以從html、css、js、編程語言、協議包分析、網路互聯原理、資料庫語法等進入,學習了這些基礎技能之後,就可以進行滲透測試的深入學習了,如web方面的學習OWASP TOP 10漏洞挖掘、主機系統服務漏洞檢測、App漏洞檢測、內網滲透等方面,最後當然是能夠編寫滲透測試報告啦。

Ⅳ 如何學習滲透測試

首先要根據自己的實際情況、確定學習的路線和方向的。就像建大樓,從頂端最華麗的那個地方開始,不可能成功。學滲透測試也一樣,沒選對入手的地方,導致學習過程中由於欠缺很多的知識點、很多概念理解不了、學習舉步維艱、很容易半途而廢。
現在我來分析下:
滲透測試屬於信息安全行業,准確的說是網路計算機/IT行業
知道它行業屬性,你大概就能清楚需要些什麼樣的基礎知識了;下面是我從非計算機網路相關專業的同學想要學習滲透測試必須掌握的知識。
1)了解基本的網路知識、什麼是IP地址(63.62.61.123),這個IP去掉點是扣扣學習群,可以免費獲取學習課程。IP地址的基本概念IP地址的基本概念、IP段劃分、什麼是A段、B段、C段等
廣域網、區域網、相關概念和IP地址劃分范圍。
2)埠的基本概念?埠的分類?
3)域名的基本概念、什麼是URL、了解TCP/IP協議、
5)了解開放式通信系統互聯參考模型(OSI)
6)了解http(超文本傳輸協議)協議概念、工作原理
7)了解WEB的靜態頁面和WEB動態頁面,B/S和C/S結構
8)了解常見的伺服器、例如、Windows server2003、Linux、UNIX等
9)了解常見的資料庫、MySQL、Mssql、、Access、Oracle、db2等
10)了解基本的網路架構、例如:Linux + Apache + MySQL + php
11)了解基本的Html語言,就是打開網頁後,在查看源碼裡面的Html語言
12)了解一種基本的腳本語言、例如PHP或者asp,jsp,cgi等
然後你想學習入門,需要學習以下最基礎的知識:
1、開始入門學習路線
1)深入學習一種資料庫語言,建議從MySQL資料庫或者SQL Server資料庫、簡單易學且學會了。
其他資料庫都差不多會了。
2)開始學習網路安全漏洞知識、SQL注入、XSS跨站腳本漏洞、CSRF、解析漏洞、上傳漏洞、命令執行、弱口令、萬能密碼、文件包含漏洞、本地溢出、遠程溢出漏洞等等
3)工具使用的學習、御劍、明小子、啊D、穿山甲(Pangolin)、Sqlmap、burpsuite抓包工具等等
2、Google hacker 語法學習
3、漏洞利用學習、SQL注入、XSS、上傳、解析漏洞等
4、漏洞挖掘學習
5、想成為大牛的話、以上都是皮毛中的皮毛,但前提是以上的皮毛都是最基礎的。
6、Linux系統命令學習、kali Linux 裡面的工具學習、Metesploit學習
7、沒事多逛逛安全論壇、看看技術大牛的文章、漏洞分析文章等
8、深入學習一門語言、Java或者Python等等,建議學習從Python開始學習、簡單易學,容易上手。
9、提升自己的專業能力、把自己練成一個技術大牛、能給你帶來一份穩定的高薪水工作,同時你還可利用自己的技術,額外的接些單子,做做副業,這個行業里是有很多單子可以接的。
10、當然想了解的可以來找我,我有時間會給你們答疑解惑的

Ⅳ 滲透測試是什麼 滲透測試有什麼特點

滲透測試是什麼?

滲透測試,是為了證明網路防禦按照預期計劃正常運行而提供的一種機制。不妨假設,你的公司定期更新安全策略和程序,時時給系統打補丁,並採用了漏洞掃描器等工具,以確保所有補丁都已打上。如果你早已做到了這些,為什麼還要請外方進行審查或滲透測試呢?因為,滲透測試能夠獨立地檢查你的網路策略,換句話說,就是給你的系統安了一雙眼睛。而且,進行這類測試的,都是尋找網路系統安全漏洞的專業人士。

滲透測試有什麼特點?

1、信息收集

信息收集分析是所有入侵攻擊的前提/前奏/基礎。通過對網路信息收集分析,可以相應地、有針對性地制定模擬黑客入侵攻擊的計劃,以提高入侵的成功率、減小暴露或被發現的幾率。信息收集的方法包括主機網路掃描、操作類型判別、應用判別、賬號掃描、配置判別等等。

2、埠掃描

通過對目標地址的TCP/UDP埠掃描,確定其所開放的服務的數量和類型,這是所有滲透測試的基礎。通過埠掃描,可以基本確定一個系統的基本信息,結合測試人員的經驗可以確定其可能存在,以及被利用的安全弱點,為進行深層次的滲透提供依據。

3、許可權提升

通過收集信息和分析,存在兩種可能性,其一是目標系統存在重大弱點:測試人員可以直接控制目標系統,然後直接調查目標系統中的弱點分布、原因,形成最終的測試報告;其二是目標系統沒有遠程重大弱點,但是可以獲得遠程普通許可權,這時測試人員可以通過該普通許可權進一步收集目標系統信息。接下來,盡最大努力獲取本地許可權,收集本地資料信息,尋求本地許可權升級的機會。這些不停的信息收集分析、許可權升級的結果將構成此次項目整個滲透測試過程的輸出。

4、溢出測試

當測試人員無法直接利用帳戶口令登陸系統時,也會採用系統溢出的方法直接獲得系統控制許可權,此方法有時會導致系統死機或從新啟動,但不會導致系統數據丟失,如出現死機等故障,只要將系統從新啟動並開啟原有服務即可。一般情況下,如果未授權,將不會進行此項測試。

5、WEB應用測試

Web腳本及應用測試專門針對Web及資料庫伺服器進行。根據最新的統計,腳本安全弱點為當前Web系統,尤其是存在動態內容的Web系統比較嚴重的安全弱點之一。利用腳本相關弱點輕則可以獲取系統其他目錄的訪問許可權,重則將有可能取得系統的控制許可權。因此對於含有動態頁面的Web、資料庫等系統,Web腳本及應用測試將是必不可少的一個環節。

6、SQL注入攻擊

SQL注入常見於應用了SQL 資料庫後端的網站伺服器,入侵者通過提交某些特殊SQL語句,最終可能獲取、篡改、控制網站伺服器端資料庫中的內容。此類漏洞是入侵者最常用的入侵方式之一。

7、檢測頁面隱藏欄位

網站應用系統常採用隱藏欄位存儲信息。許多基於網站的電子商務應用程序用隱藏欄位來存儲商品價格、用戶名、密碼等敏感內容。惡意用戶通過操作隱藏欄位內容達到惡意交易和竊取信息等行為,是一種非常危險的漏洞。

8、跨站攻擊

入侵者可以藉助網站來攻擊訪問此網站的終端用戶,來獲得用戶口令或使用站點掛馬來控制客戶端。

9、Cookie利用

網站應用系統常使用cookies 機制在客戶端主機上保存某些信息,例如用戶ID、口令、時戳等。入侵者可能通過篡改cookies 內容,獲取用戶的賬號,導致嚴重的後果。