精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

PHP場景中g(shù)etshell防御思路分享

安全 應(yīng)用安全
WEB應(yīng)用漏洞導(dǎo)致的入侵時有發(fā)生,掃描器和WAF并不能解決所有的問題,于是嘗試在主機(jī)側(cè)針對PHP環(huán)境做了一個防御方案。很榮幸的邀請到TSRC部分白帽子做了一次對抗演習(xí),本文主要分享一下防御思路。防御方案主要想解決的問題是getshell、主機(jī)敏感文件泄漏等問題。

1 背景概述

WEB應(yīng)用漏洞導(dǎo)致的入侵時有發(fā)生,掃描器和WAF并不能解決所有的問題,于是嘗試在主機(jī)側(cè)針對PHP環(huán)境做了一個防御方案。很榮幸的邀請到TSRC部分白帽子做了一次對抗演習(xí),本文主要分享一下防御思路。

防御方案主要想解決的問題是getshell、主機(jī)敏感文件泄漏等問題。于是乎出了下面這樣一個題目:部署了防御方案的Nginx + PHP 的WEB環(huán)境,提供一個上傳入口,可上傳任意文件。找到WEB目錄下的一個flag文件讀取到內(nèi)容即算突破。

2 PHP擴(kuò)展

防御方案使用了PHP擴(kuò)展來完成阻斷。PHP內(nèi)核支持C/C++開發(fā)一些擴(kuò)展功能,并且提供了一個框架 – ext_skel幫助生成基本的代碼簡化開發(fā),由于PHP擴(kuò)展并不涉及底層的資源管理,所以編寫一個PHP擴(kuò)展和編寫一個C應(yīng)用程序是一樣的。下圖展示了PHP擴(kuò)展所處的結(jié)構(gòu)層次,擴(kuò)展位于PHP內(nèi)核ZEND 和 PHP應(yīng)用層代碼之間,那么利用PHP擴(kuò)展可以:

1) 監(jiān)控PHP應(yīng)用層代碼的執(zhí)行細(xì)節(jié),包括執(zhí)行CGI、函數(shù)名、參數(shù)等;

2) 調(diào)用PHP內(nèi)核ZEND提供的API接口,包括禁用類、修改配置選項等。

PHP場景中g(shù)etshell防御思路分享

圖1 PHP語言的結(jié)構(gòu)

3 相關(guān)知識

3.1 HOOKPHP代碼

PHP是解釋型語言,代碼被翻譯為中間字節(jié)碼由ZEND引擎解析執(zhí)行。PHP把中間字節(jié)碼稱之為OPCODE,每個OPCODE對應(yīng)ZEND底層的一個處理函數(shù),ZEND引擎最終執(zhí)行這個處理函數(shù)。實現(xiàn)HOOK功能只需要改變HOOK OPCODE對應(yīng)的處理函數(shù)即可,而ZEND預(yù)先就提供了一個現(xiàn)成的接口:zend_set_user_opcode_handler。防御方案只需要HOOK以下三個OPCODE:

ZEND_INCLUDE_OR_EVAL — eval、require等

ZEND_DO_FCALL — 函數(shù)執(zhí)行system等

ZEND_DO_FCALL_BY_NAME — 變量函數(shù)執(zhí)行 $func = “system”;$func();

舉例:

ZEND_DO_FCALL這個OPCODE對應(yīng)的功能是函數(shù)調(diào)用,如果需要HOOK所有的函數(shù)調(diào)用:

1) 在模塊初始化函數(shù)中使用zend_set_user_opcode_handler修改ZEND_DO_FCALL新的處理函數(shù)為mysub:

PHP_MINIT_FUNCTION(phpips){

zend_set_user_opcode_handler(ZEND_DO_FCALL, mysub);

return SUCCESS;

}

2) 在自定義函數(shù)中實現(xiàn)自己需要的功能并返回原來的處理函數(shù):

void mysub(){

自定義功能;

return ZEND_USER_OPCODE_DISPATCH;

}

3.2 ZEND接口

HOOK之外還需要獲取一些基本信息或功能,比如:

1) 獲取執(zhí)行的PHP腳本名,可調(diào)用ZEND的接口zend_get_executed_filename:

char *cgi_name = (char*)zend_get_executed_filename(TSRMLS_C);

2) 禁用一些類庫,可使用zend_disable_class接口;

ZEND提供了很多豐富的接口,可根據(jù)需求選擇調(diào)用。

3.3 數(shù)據(jù)結(jié)構(gòu)

PHP是弱類型語言,其上層并不區(qū)分變量類型,變量底層對應(yīng)的是一個union結(jié)構(gòu)體,以php-5.3.6版本舉例,結(jié)構(gòu)體在Zend/zend.h文件中定義;內(nèi)容如下:

typedef union _zvalue_value {

long lval; /* longvalue */

double dval; /* double value */

struct {

char *val;

int len;

} str;

HashTable *ht; /* hash table value*/

zend_object_value obj;

} zvalue_value;

PHP是在底層區(qū)分開了變量類型;在union結(jié)構(gòu)體中有個非常重要的結(jié)構(gòu)體HashTable,PHP中的數(shù)組結(jié)構(gòu)就是利用HashTable這個結(jié)構(gòu)體實現(xiàn),如果變量是個數(shù)組,獲取變量內(nèi)容需要遍歷這塊HashTable,數(shù)據(jù)結(jié)構(gòu)這塊不做太多介紹。ZEND底層用zval這個結(jié)構(gòu)體存儲變量,同時ZEND提供了幾個宏可以方便的轉(zhuǎn)換zval到具體的數(shù)據(jù)類型,比如把zval類型轉(zhuǎn)換為字符串 – zval el; Z_STRVAL_P(el),常用的還有:

Z_LVAL_P、Z_DVAL_P、Z_ARRVAL_P等,以上宏列表在 Zend/zend_operators.h有定義。

4 規(guī)則策略

4.1 基本思路

我們需要解決的問題是getshell、主機(jī)敏感文件泄漏等問題。如果限制住PHP腳本執(zhí)行命令 和 翻閱文件的功能,就達(dá)到了目的。同時,由于讀取文件的接口非常多,使用場景也較多,因此采取禁用打開目錄接口來側(cè)面達(dá)到禁止翻閱文件的目的,不能遍歷目錄便無法得到文件名,可以有效的達(dá)到目標(biāo)。故最終形成的最終策略如下:

1) 禁用掉執(zhí)行命令的接口

2) 禁用掉打開目錄的接口

禁用函數(shù)有一些需要注意的問題:

1) PHP接口還是比較繁多復(fù)雜的,除了system、exec、opendir、scandir常用函數(shù)之外,一些生僻函數(shù)比如glob等函數(shù)都要考慮全面,另外還有一些回調(diào)函數(shù)、反射類(PS:部分考慮不全被blackeye和雪人繞過)

2) PHP SPL提供的一些類庫有文件管理的功能,也需要禁止,比如DirectoryIterator(不過好像沒有白帽子使用過SPL)

4.2 對抗變形

PHP使用assert或preg_replace /e執(zhí)行代碼,調(diào)用zend_get_executed_filename獲取的PHP腳本名中會帶有辨別標(biāo)識,assert對應(yīng)的是assert code,preg_replace對應(yīng)的是regexp code;當(dāng)發(fā)現(xiàn)這些特殊的腳本執(zhí)行了system等4.1中提高的高危函數(shù)直接阻斷。以下圖的nonalphanumeric -webshell舉例:

變形webshell解析后的形式和$_GET[1]($_GET[2])類似,比如傳入1=assert&2=system(whoami)執(zhí)行代碼,PHP擴(kuò)展層監(jiān)控到system函數(shù)執(zhí)行,并且發(fā)現(xiàn)PHP腳本名帶regexp code標(biāo)識,清晰的知道是preg_replace的代碼執(zhí)行了調(diào)用了system,阻斷system。Assert函數(shù)同理。總結(jié):擴(kuò)展并不關(guān)注在靜態(tài)層如何編碼運(yùn)算或加密,擴(kuò)展只監(jiān)控最后的行為,所以可以很好的解決目前的變形難題。

 

1

 

圖2nonalphanumeric – webshell

4.3 減少誤殺

有時正常的PHP腳本也需要用到命令執(zhí)行的功能,如何保證其正常運(yùn)行,不被我們的防御策略阻斷呢?這里提供三種思路:

1) 寫入權(quán)限和執(zhí)行命令權(quán)限互斥

考慮到入侵者利用上傳漏洞或者其他0DAY getshell得到的文件大多會有W寫權(quán)限,防御方往往希望阻止這部分文件擁有過高的權(quán)限。

那么,我們可以去除正常PHP腳本的可寫權(quán)限,然后只對有寫權(quán)限的PHP腳本實施命令執(zhí)行等防御策略的阻斷邏輯。這樣即不會影響到業(yè)務(wù)的使用,又達(dá)到了預(yù)設(shè)場景的防護(hù)目標(biāo)。不過這樣的思路,需要禁用chmod等可以修改文件權(quán)限的函數(shù)。

2) 使用白名單邏輯

粗暴一點(diǎn)的可以用文件名白名單,也就是業(yè)務(wù)報備過的文件不受阻斷,其它不認(rèn)識的文件一律禁止。優(yōu)雅一點(diǎn)的可以對函數(shù)參數(shù)做白名單,比如提取正常PHP腳本執(zhí)行命令的參數(shù)或者代碼特征,對其進(jìn)行放行,不認(rèn)識的特征一律阻斷。

3) 使用黑名單邏輯

設(shè)定一些已知惡意腳本的黑特征參數(shù),類似于殺毒軟件早期的特征碼思路。

上述思路在企業(yè)推廣時,需要和業(yè)務(wù)有足夠充分的配合,也都有不完美的地方,如果大家有更多方案或者思路,歡迎與我共同探討。

5 未來

利用PHP擴(kuò)展可以做的事情還是比較多,比如在漏洞檢測方面、對數(shù)據(jù)庫函數(shù)參數(shù)過濾、阻斷SQL注入、阻斷存儲型XSS等場景都有非常大的想象空間。甚至在代碼審計這塊也可以考慮,國內(nèi)有個大牛已經(jīng)有比較成熟的開源產(chǎn)品,TAINT (作者:laruence),大家可能都已經(jīng)比較熟悉了,就暫時不做贅述了。

行文比較倉促,有不足的地方請諒解,有任意疑問或建議歡迎聯(lián)系pandas(小毛驢)切磋交流。

責(zé)任編輯:藍(lán)雨淚 來源: TSRC
相關(guān)推薦

2010-09-16 20:54:21

2013-10-12 13:40:09

2010-10-25 12:10:39

SQL注入

2009-03-11 17:04:53

2023-12-03 21:52:20

2010-08-19 13:49:50

2024-04-19 13:57:30

索引數(shù)據(jù)庫查詢

2009-08-05 09:09:33

2013-04-23 08:59:19

2017-09-15 11:29:41

2009-12-07 11:11:46

PHP顯示圖片

2015-07-09 09:35:37

2009-12-09 17:33:22

PHP性能優(yōu)化

2015-09-22 10:25:13

2023-05-10 10:46:38

2018-10-24 10:38:44

云計算云租戶企業(yè)云

2011-07-30 13:01:23

2009-12-03 16:54:36

PHP獲取中國IP段

2009-05-18 10:23:43

文件上傳PHPFILE函數(shù)

2010-03-24 11:21:11

點(diǎn)贊
收藏

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

天堂av在线资源| 自拍视频国产精品| 久久免费高清视频| xx欧美撒尿嘘撒尿xx| 久久99久久98精品免观看软件| 夜鲁夜鲁夜鲁视频在线播放| 66国产精品| 91福利国产成人精品照片| 国产99视频精品免费视频36| 日本美女黄色一级片| 欧美一区久久久| 99视频在线观看一区三区| 久热99视频在线观看| 邪恶网站在线观看| 国产最新视频在线| 国产乱码精品| 精品视频中文字幕| 久久黄色片视频| 三级在线观看网站| 99香蕉国产精品偷在线观看| 亚洲第一精品自拍| 国产日韩欧美精品在线观看| 亚洲精品成人区在线观看| 久久久久蜜桃| 亚洲精品一区中文| 欧美xxxx黑人| 色呦呦在线观看视频| 国产精品白丝jk黑袜喷水| 久久久国产精品免费| 视频免费1区二区三区| 欧美成人三区| 国产乱理伦片在线观看夜一区| 国产91成人video| 欧美熟妇一区二区| 国产麻豆久久| 18欧美亚洲精品| 99re视频| 五月婷婷亚洲综合| 欧美肉体xxxx裸体137大胆| 色美美综合视频| 欧美一区二区视频在线播放| 亚洲男女视频在线观看| 亚洲精品乱码| 亚洲欧美日韩在线一区| 最新中文字幕免费视频| 色戒汤唯在线观看| 日本一区二区三级电影在线观看 | 91麻豆精品国产91久久久资源速度| 亚洲精品一区二区三区av| 国产又粗又黄又爽视频| 中文av一区| 亚洲国产精品大全| 国产精品偷伦视频免费观看了| 阿v视频在线| 国产日韩成人精品| 91免费综合在线| 日韩成年人视频| 精品日韩一区| 国产一区二区成人| 无码人妻丰满熟妇区毛片蜜桃精品 | 欧美精品久久久久久久久| 麻豆国产精品一区| 日韩一区二区三区免费| 日韩理论片一区二区| av成人免费观看| 精品国产99久久久久久宅男i| 久久久久久美女精品| 中文欧美在线视频| 在线观看免费黄色网址| jizzjizzjizz欧美| 91国产免费观看| 9久久婷婷国产综合精品性色 | 久久久久久国产精品美女| 校园春色 亚洲| 在线看成人短视频| 日韩一级片网址| 亚洲爆乳无码专区| 欧美aaaaaaa| 国产精品视频你懂的| 国产精品一区二区免费看| 自拍偷拍精品视频| 亚洲毛片在线| 91爱视频在线| 欧美黑吊大战白妞| 亚洲精品三级| 国产成+人+综合+亚洲欧洲| 久久中文字幕无码| 99热在线成人| 国产午夜精品全部视频在线播放 | 一区三区在线欧| 自拍偷拍亚洲区| 欧美日韩国产精品综合| 性色一区二区| 欧美激情女人20p| 国产一区在线观看免费| 欧美.www| 欧美久久久精品| 日本一级免费视频| 国产在线播放精品| 日韩一级片在线播放| 亚洲啪av永久无码精品放毛片 | 欧美精品1区| 亚洲一区二区久久久| 欧美精品久久久久久久久46p| 精品免费视频| 久久久久久91| 亚洲高清视频免费观看| 国产成人亚洲综合a∨婷婷图片 | 欧美乱大交xxxxx潮喷l头像| 新片速递亚洲合集欧美合集| 91精品国产色综合久久ai换脸 | 91精品国产综合久久久蜜臀九色| 一区二区电影| 欧美中文字幕在线播放| 国产精品美女久久久久av爽| 美女在线一区二区| 国产精品视频公开费视频| 精品免费囯产一区二区三区| 久久av资源网| 成人激情综合网| 国产乱色精品成人免费视频| 精品亚洲porn| 亚洲一区二区三区四区视频| 国产情侣自拍小视频| 国产精品资源网| 日韩视频在线播放| 在线观看完整版免费| 中文字幕在线一区免费| 在线观看日韩片| 中文字幕中文字幕在线中高清免费版| 亚洲精品免费电影| www.av蜜桃| 成人免费无遮挡| 欧美中文字幕一区| 17c国产在线| 国产欧美日韩精品一区二区免费| 尤物九九久久国产精品的特点| 一级片久久久久| 久久久久国产| 国产精品欧美亚洲777777| 亚洲欧洲视频在线观看| 久久你懂得1024| 亚洲乱码一区二区三区三上悠亚| 美女91在线看| 亚洲福利小视频| 国产亚洲精品久久久久久打不开| 国产在线视频精品一区| 国产二区不卡| 羞羞视频在线免费国产| 91精品国产美女浴室洗澡无遮挡| 少妇愉情理伦三级| 麻豆一区二区在线| 国产98在线|日韩| 欧美人与禽猛交乱配| 日韩免费一区二区三区在线播放| 国产熟女高潮一区二区三区| 精品国产91| 国产精品成人免费电影| 99精品视频免费看| 日韩美女视频一区二区| 小早川怜子一区二区三区| 久久久伦理片| www日韩欧美| 91九色丨porny丨肉丝| 成人国产精品视频| 一本色道久久综合亚洲二区三区| 性网站在线观看| 欧美不卡一区二区三区| 国产精品av久久久久久无| 久久久久久自在自线| 97视频中文字幕| 国产青青草在线| 亚洲国产va精品久久久不卡综合| 日韩爱爱小视频| 99久久激情| 97超碰资源| 成年人在线网站| 亚洲人成欧美中文字幕| 久草视频中文在线| 99riav久久精品riav| 永久免费在线看片视频| 日本在线中文字幕一区二区三区| 综合国产在线视频| 精品人妻久久久久一区二区三区| 亚洲午夜av在线| 激情五月婷婷基地| 欧美日韩福利| 欧美一区二区三区四区五区六区| www在线看| 日韩一卡二卡三卡| 日韩成人免费在线视频| 国产三级欧美三级| 视频区 图片区 小说区| 成人在线国产| 日韩av日韩在线观看| 日本黄色大片视频| 亚洲一区二区三区在线看| 加勒比精品视频| 蜜桃一区二区三区在线观看| 成人av在线播放观看| 99热这里有精品| 中文字幕日韩精品在线观看| 国产ts变态重口人妖hd| 色综合天天做天天爱| 色婷婷精品久久二区二区密| 日本va欧美va瓶| 欧美一区免费视频| 日本99精品| 久久91亚洲人成电影网站| 欧美日韩国产中文字幕在线| 欧美日韩国产在线播放| 给我免费观看片在线电影的| 麻豆精品国产传媒mv男同| 国产 日韩 亚洲 欧美| 久久麻豆精品| 91精品视频大全| 中文字幕一区久| 欧美激情精品久久久久| 在线激情小视频| 日韩大片免费观看视频播放| 国产精品久久久久久久久久久久久久久久久| 中文字幕第一页久久| 欧美三级理论片| 亚洲乱亚洲高清| 成人污网站在线观看| 成人黄色av| 精品在线视频一区二区三区| 色老太综合网| 国模精品系列视频| 欧美日韩色网| 久久伊人精品天天| 欧美成年黄网站色视频| 伊人一区二区三区久久精品 | 国产亚洲精品91在线| 日韩一卡二卡在线| 精品国产乱码久久久久久1区2区 | 国产一区二区色| 久草免费在线| 日韩欧美一二区| 国产精品嫩草影院精东| 欧美三级日韩三级国产三级| 国产67194| 99九九99九九九视频精品| 无套白嫩进入乌克兰美女| 男人的天堂久久精品| 亚洲精品一二三四五区| 天堂av在线一区| 99精品视频网站| 国产伦精品一区二区三区在线播放 | 9.1麻豆精品| 国产精品一区二区久久| 特级毛片在线| 欧美精品成人在线| av资源中文在线| 日韩在线视频免费观看| www香蕉视频| 91精品国产欧美一区二区成人| 国产毛片久久久久| 91麻豆精品国产91久久久久推荐资源| 一区二区三区在线视频免费| 日本爱爱小视频| 国产乱理伦片在线观看夜一区 | 精品91久久| 国产精品91一区| 91精品影视| 国产精品偷伦视频免费观看国产| 日韩一级特黄| 欧美在线一级va免费观看| 日本不卡1234视频| 国产精品白丝jk喷水视频一区| 日本精品另类| 成人中文字幕在线观看| 综合视频一区| 成人av在线网址| 国产精品久久久久久久久久辛辛 | 国产成人精品网址| 天堂…中文在线最新版在线| 亚洲精品护士| 欧美日韩在线不卡视频| 黄色另类av| 中文字幕一区二区三区乱码| 中文字幕免费一区二区| 国产午夜福利100集发布| 麻豆久久精品| 在线播放黄色av| 97精品久久久午夜一区二区三区| www色com| 久久新电视剧免费观看| 中文字幕第69页| 亚洲电影在线播放| 中文字幕在线播| 疯狂蹂躏欧美一区二区精品| 樱花视频在线免费观看| 精品免费在线视频| 欧美成人精品网站| 精品福利一二区| 成a人片在线观看www视频| 亚洲欧美国产高清va在线播| 日本中文字幕在线看| 一区二区三区视频在线| 污污网站在线观看| 国产精品va在线| 6080亚洲理论片在线观看| 日韩欧美亚洲v片| 伊人激情综合| 可以看毛片的网址| 免费观看成人av| 欧美黑人欧美精品刺激| 一区二区在线电影| 黄色一区二区视频| 亚洲加勒比久久88色综合| 天堂成人在线观看| 日韩有码片在线观看| 欧美13videosex性极品| av蓝导航精品导航| 91视频综合| 免费午夜视频在线观看| 成人精品免费网站| 亚洲成人生活片| 欧美精品亚洲一区二区在线播放| 国产影视一区二区| 亚洲欧美一区二区三区四区| 狂野欧美性猛交xxxxx视频| 成人黄色免费看| 精品一区二区三区在线 | 日韩一区二区免费高清| 黄色毛片在线看| 7777免费精品视频| 大桥未久女教师av一区二区| 中国一级黄色录像| 久久超碰97中文字幕| 18啪啪污污免费网站| 色香色香欲天天天影视综合网| 日本wwwxxxx| 国内精品免费午夜毛片| 57pao国产一区二区| 肉大捧一出免费观看网站在线播放| 午夜亚洲福利| 国产5g成人5g天天爽| 亚洲人成网站影音先锋播放| 亚洲一级黄色大片| 精品日产卡一卡二卡麻豆| 国产精品一卡二卡三卡| 成人a在线视频| 国产精品99久久精品| 亚欧激情乱码久久久久久久久| 国产丝袜欧美中文另类| 亚洲av人无码激艳猛片服务器| 亚洲欧美一区二区三区情侣bbw | 91中文字幕一区| 天天射—综合中文网| 黄色aaaaaa| 亚洲免费电影在线| 亚洲天堂一区在线观看| 日韩av一区二区在线观看| 蜜桃av.网站在线观看| 久久久福利视频| 亚洲精品国产偷自在线观看| 成人亚洲免费视频| 亚洲女同一区二区| 亚洲av色香蕉一区二区三区| 欧美激情亚洲一区| 欧美亚视频在线中文字幕免费| 中文字幕日韩一区二区三区不卡| 久久99久久99| 久久精品99久久久久久| 亚洲爱爱爱爱爱| 东京一区二区| 制服国产精品| 成人一区二区视频| 欧美色视频一区二区三区在线观看| 欧美精品1区2区| 国产丝袜在线播放| 欧美激情导航| 国产中文一区| 女人被狂躁c到高潮| 欧美在线视频不卡| 菠萝菠萝蜜在线视频免费观看| 热草久综合在线| 日韩免费在线| 成年人网站大全| 成人免费在线视频观看| 亚洲欧美高清视频| 日韩av男人的天堂| 中文字幕亚洲精品乱码| 国产激情视频网站| 欧美色网一区二区| 青青青国内视频在线观看软件| 蜜桃欧美视频| 99日韩精品| 亚洲一二三四五六区| 亚洲成色999久久网站| 电影一区二区| 色欲色香天天天综合网www| 欧美国产在线观看| 免费看黄色一级视频| 国产精品视频一区二区三区四| 欧美在线亚洲| 五月婷婷欧美激情| 亚洲国产一区自拍|