欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

linux下c語言中隱藏進(jìn)程命令行參數(shù)(例如輸入密碼等高危操作)

 更新時(shí)間:2021年01月23日 14:21:20   作者:janbar  
啟動(dòng)程序很多時(shí)候用命令行參數(shù)可以很方便,做到簡化一些配置,但是輸入用戶名密碼等操作,如果通過進(jìn)程查看工具直接看到密碼就太不安全了,這里就為大家分享一下方法

前言

啟動(dòng)程序很多時(shí)候用命令行參數(shù)可以很方便,做到簡化一些配置,但是輸入用戶名密碼等操作,如果通過進(jìn)程查看工具直接看到密碼就太不安全了。
因此很有必要研究如何隱藏命令行參數(shù)中的某些字段,當(dāng)然做成配置文件也是極好的,但是無疑給運(yùn)行程序增加額外操作。編輯保存配置文件也會(huì)費(fèi)點(diǎn)事。
我結(jié)合網(wǎng)上找到的一些方案,以及自己總結(jié)一個(gè)方案,記下筆記。

復(fù)寫argv參數(shù)

該方案只在Linux下的C語言中驗(yàn)證成功,因?yàn)閣indow下都是win32api獲取命令行參數(shù),但是沒有設(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ù)寫argv,此時(shí)既可以正常使用命令行參數(shù),也可以隱藏參數(shù)。

獲取標(biāo)準(zhǔn)輸入

看到C語言隱藏參數(shù)如此簡單,但是我在window下驗(yàn)證C語言失敗了,執(zhí)行wmic process where caption="a.exe" get caption,commandline /value或者命令行參數(shù)仍然能看到。

因此我想到了通過讀取標(biāo)準(zhǔn)輸入來獲取程序傳遞參數(shù),但是需要在運(yùn)行程序后敲鍵盤輸入?yún)?shù),不過使用echo可以完美解決該問題。
鑒于C語言已經(jīng)很久沒使用了,還是用go語言來寫實(shí)例程序吧。順便提一句go獲取命令行參數(shù)源碼,我看了也是沒辦法修改值的,包括window和Linux。
如下所示,使用go的flag庫獲取標(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下測試:

在window下測試:

總結(jié)

安全運(yùn)行程序,隱藏命令行參數(shù)在某些場景下還是很重要的,因此研究了一下,發(fā)現(xiàn)也沒想象中那么困難。
需要注意的是,對于會(huì)記錄命令行歷史的Linux,使用echo還是不太安全的。但是也可以在執(zhí)行程序后輸入命令行參數(shù),就是麻煩些。
總之最安全的還是做一個(gè)密碼文件,通過讀取密碼文件,只要?jiǎng)e人沒有該密碼文件就不行,或者給密碼文件加密。
加密和破解總是相對的,沒有絕對安全的方案,只有相對安全的方案。

相關(guān)文章

最新評論