linux下c語(yǔ)言中隱藏進(jìn)程命令行參數(shù)(例如輸入密碼等高危操作)
前言
啟動(dòng)程序很多時(shí)候用命令行參數(shù)可以很方便,做到簡(jiǎn)化一些配置,但是輸入用戶名密碼等操作,如果通過(guò)進(jìn)程查看工具直接看到密碼就太不安全了。
因此很有必要研究如何隱藏命令行參數(shù)中的某些字段,當(dāng)然做成配置文件也是極好的,但是無(wú)疑給運(yùn)行程序增加額外操作。編輯保存配置文件也會(huì)費(fèi)點(diǎn)事。
我結(jié)合網(wǎng)上找到的一些方案,以及自己總結(jié)一個(gè)方案,記下筆記。
復(fù)寫(xiě)argv參數(shù)
該方案只在Linux下的C語(yǔ)言中驗(yàn)證成功,因?yàn)閣indow下都是win32api獲取命令行參數(shù),但是沒(méi)有設(shè)置這個(gè),估計(jì)window不支持這種騷操作吧。
該方案就是在執(zhí)行程序時(shí)將argv內(nèi)容修改,如下源碼,僅供參考。
#include <stdio.h> #include <stdlib.h> #include <string.h> int main(int argc,char *argv[]) { int i,j; for (i=1;i<argc;i++) { for (j=strlen(argv[i])-1;j>=0;j--) { argv[i][j] = 'x'; } } getchar(); return 0; }
如下圖所示,命令行參數(shù)已經(jīng)隱藏了。正常程序,可以將argv復(fù)制到內(nèi)存變量,然后立即復(fù)寫(xiě)argv,此時(shí)既可以正常使用命令行參數(shù),也可以隱藏參數(shù)。
獲取標(biāo)準(zhǔn)輸入
看到C語(yǔ)言隱藏參數(shù)如此簡(jiǎn)單,但是我在window下驗(yàn)證C語(yǔ)言失敗了,執(zhí)行wmic process where caption="a.exe" get caption,commandline /value或者命令行參數(shù)仍然能看到。
因此我想到了通過(guò)讀取標(biāo)準(zhǔn)輸入來(lái)獲取程序傳遞參數(shù),但是需要在運(yùn)行程序后敲鍵盤(pán)輸入?yún)?shù),不過(guò)使用echo可以完美解決該問(wèn)題。
鑒于C語(yǔ)言已經(jīng)很久沒(méi)使用了,還是用go語(yǔ)言來(lái)寫(xiě)實(shí)例程序吧。順便提一句go獲取命令行參數(shù)源碼,我看了也是沒(méi)辦法修改值的,包括window和Linux。
如下所示,使用go的flag庫(kù)獲取標(biāo)準(zhǔn)輸入的一行內(nèi)容,用于解析命令行參數(shù),源碼如下所示:
package main import ( "bufio" "flag" "fmt" "os" "strings" "time" ) func main() { fs := flag.NewFlagSet(os.Args[0], flag.ExitOnError) s := fs.String("s", "", "string") i := fs.Int("i", 123, "int") argv, _ := bufio.NewReader(os.Stdin).ReadString('\n') fs.Parse(strings.Fields(argv)) fmt.Println(*s, *i) time.Sleep(time.Minute) }
在Linux下測(cè)試:
在window下測(cè)試:
總結(jié)
安全運(yùn)行程序,隱藏命令行參數(shù)在某些場(chǎng)景下還是很重要的,因此研究了一下,發(fā)現(xiàn)也沒(méi)想象中那么困難。
需要注意的是,對(duì)于會(huì)記錄命令行歷史的Linux,使用echo還是不太安全的。但是也可以在執(zhí)行程序后輸入命令行參數(shù),就是麻煩些。
總之最安全的還是做一個(gè)密碼文件,通過(guò)讀取密碼文件,只要?jiǎng)e人沒(méi)有該密碼文件就不行,或者給密碼文件加密。
加密和破解總是相對(duì)的,沒(méi)有絕對(duì)安全的方案,只有相對(duì)安全的方案。
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)銀行管理系統(tǒng)(文件操作)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)銀行管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03C語(yǔ)言 坐標(biāo)移動(dòng)詳解及實(shí)例代碼
這篇文章主要介紹了C語(yǔ)言 坐標(biāo)移動(dòng)詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-01-01使用udp發(fā)送>=128K的消息會(huì)報(bào)ENOBUFS的錯(cuò)誤的解決方法
在項(xiàng)目中選擇了unix域的數(shù)據(jù)報(bào)套接口。在使用過(guò)程中碰到了如下,問(wèn)題:發(fā)送<128K的消息時(shí),客戶、進(jìn)程可以正常收發(fā)消息;發(fā)送>=128K的消息時(shí),發(fā)送端(sendto)返回ENOBUFS的錯(cuò)誤。下面小編來(lái)詳細(xì)說(shuō)下2019-05-05C++實(shí)現(xiàn)Linux下彈出U盤(pán)的方法
這篇文章主要介紹了C++實(shí)現(xiàn)Linux下彈出U盤(pán)的方法,實(shí)例分析了C++在Linux平臺(tái)上進(jìn)行IO操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07