溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在linux中利用c語言中隱藏進程命令行參數(shù)

發(fā)布時間:2021-01-25 16:03:59 來源:億速云 閱讀:407 作者:Leah 欄目:開發(fā)技術

今天就跟大家聊聊有關怎么在linux中利用c語言中隱藏進程命令行參數(shù),可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

復寫argv參數(shù)

該方案只在Linux下的C語言中驗證成功,因為window下都是win32api獲取命令行參數(shù),但是沒有設置這個,估計window不支持這種騷操作吧。
該方案就是在執(zhí)行程序時將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復制到內(nèi)存變量,然后立即復寫argv,此時既可以正常使用命令行參數(shù),也可以隱藏參數(shù)。

怎么在linux中利用c語言中隱藏進程命令行參數(shù)

獲取標準輸入

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

怎么在linux中利用c語言中隱藏進程命令行參數(shù)

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

怎么在linux中利用c語言中隱藏進程命令行參數(shù)

在window下測試:

怎么在linux中利用c語言中隱藏進程命令行參數(shù)

看完上述內(nèi)容,你們對怎么在linux中利用c語言中隱藏進程命令行參數(shù)有進一步的了解嗎?如果還想了解更多知識或者相關內(nèi)容,請關注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI