c语言怎么隐藏进程命令行参数
本文小编为大家详细介绍“c语言怎么隐藏进程命令行参数”,内容详细,步骤清晰,细节处理妥当,希望这篇“c语言怎么隐藏进程命令行参数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
复写argv参数
该方案只在linux下的c语言中验证成功,因为window下都是win32api获取命令行参数,但是没有设置这个,估计window不支持这种骚操作吧。
该方案就是在执行程序时将argv内容修改,如下源码,仅供参考。
#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;
}
如下图所示,命令行参数已经隐藏了。正常程序,可以将argv复制到内存变量,然后立即复写argv,此时既可以正常使用命令行参数,也可以隐藏参数。
获取标准输入
看到c语言隐藏参数如此简单,但是我在window下验证c语言失败了,执行wmic process where caption="a.exe" get caption,commandline /value或者命令行参数仍然能看到。
因此我想到了通过读取标准输入来获取程序传递参数,但是需要在运行程序后敲键盘输入参数,不过使用echo可以完美解决该问题。
鉴于c语言已经很久没使用了,还是用go语言来写实例程序吧。顺便提一句go获取命令行参数源码,我看了也是没办法修改值的,包括window和linux。
如下所示,使用go的flag库获取标准输入的一行内容,用于解析命令行参数,源码如下所示:
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('
')
fs.parse(strings.fields(argv))
fmt.println(*s, *i)
time.sleep(time.minute)
}
在linux下测试:
在window下测试:
相关文章