千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 什么是命令注入?如何形成的?

什么是命令注入?如何形成的?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-08 18:53:00 1696762380

  在網絡安全領域,我們經常會看到或聽到一些比較陌生的專業(yè)術語,比如“命令注入”,那么什么是命令注入?如何形成的?具體內容請看下文。

 

  什么是命令注入?

  Command Injection,即命令注入攻擊,是指由于嵌入式應用程序或者web應用程序對用戶提交的數(shù)據(jù)過濾不嚴格,導致黑客可以通過構造特殊命令字符串的方式,將數(shù)據(jù)提交至應用程序中,并利用該方式執(zhí)行外部程序或系統(tǒng)命令實施攻擊,非法獲取數(shù)據(jù)或者網絡資源等。

  在命令注入的漏洞中,最為常見的是PHP的命令注入。PHP命令注入攻擊存在的主要原因是web應用程序員在應用PHP語言中一些具有命令執(zhí)行功能的函數(shù)時,對用戶提交的數(shù)據(jù)內容沒有進行嚴格的過濾就帶入函數(shù)中執(zhí)行而造成的。例如,當黑客提交的數(shù)據(jù)內容為向網站目錄寫入PHP文件時,就可以通過該命令注入攻擊漏洞寫入一個PHP后門文件,進而實施進一步的滲透攻擊。

  原理:Web應用在調用這些函數(shù)執(zhí)行系統(tǒng)命令的時候,在沒有做好過濾用戶輸入的情況下,如果用戶將自己的輸入作為系統(tǒng)命令的參數(shù)拼接到命令行中,就會造成命令注入的漏洞。

  命令注入攻擊是如何形成的?

  嵌入式應用程序或者web應用程序有時需要調用一些系統(tǒng)命令的函數(shù),如Linux C中的system(),exec(),shell-exec()等等,當用戶能夠控制這些函數(shù)中的參數(shù)時,就可以將惡意參系統(tǒng)命令拼接到正常命令中,從而造成命令注入攻擊設備系統(tǒng)。

  命令注入的形成需要如下三個條件:

  1、使用了內部調用shell的函數(shù):system(),exec()等。

  2、將外界傳入的參數(shù)沒有足夠的過濾,直接傳遞給內部調用shell的函數(shù)。

  3、參數(shù)中shell的元字符沒有被轉義。

  危害:繼承嵌入式應用程序或者web應用程序的權限去執(zhí)行系統(tǒng)命令讀寫執(zhí)行文件,導致系統(tǒng)有可能會被惡意攻擊或者泄露系統(tǒng)用戶信息。

tags: 命令注入
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT