我的终端使用STDIN 3
(/proc/xxxx/fd/0 -> /dev/pts/3
)
所以如果(在另一个终端)我这样做:
echo 'do_something_command' > /dev/pts/3
该命令显示在我的第一个(pts/3
)终端中,但该命令未执行。如果(在此终端pts/3
)我正在等待来自stdin
的某些数据的程序中,则数据会写在屏幕上,但程序不会从stdin
捕获数据
我想要做的是执行命令"do_something_command"
,而不仅仅是显示它。
有人可以向我解释这种行为吗?我如何实现自己的意图?
答案 0 :(得分:6)
我完全明白你的要求。你可以通过在C中编写和执行一小段代码来实现这一点。这应该会给你一些想法。
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
#include <string.h>
#include <unistd.h>
void print_help(char *prog_name) {
printf("Usage: %s [-n] DEVNAME COMMAND\n", prog_name);
printf("Usage: '-n' is an optional argument if you want to push a new line at the end of the text\n");
printf("Usage: Will require 'sudo' to run if the executable is not setuid root\n");
exit(1);
}
int main (int argc, char *argv[]) {
char *cmd, *nl = "\n";
int i, fd;
int devno, commandno, newline;
int mem_len;
devno = 1; commandno = 2; newline = 0;
if (argc < 3) {
print_help(argv[0]);
}
if (argc > 3 && argv[1][0] == '-' && argv[1][1] == 'n') {
devno = 2; commandno = 3; newline=1;
} else if (argc > 3 && argv[1][0] == '-' && argv[1][1] != 'n') {
printf("Invalid Option\n");
print_help(argv[0]);
}
fd = open(argv[devno],O_RDWR);
if(fd == -1) {
perror("open DEVICE");
exit(1);
}
mem_len = 0;
for (i = commandno; i < argc; i++) {
mem_len += strlen(argv[i]) + 2;
if (i > commandno) {
cmd = (char *)realloc((void *)cmd, mem_len);
} else { // i == commandno
cmd = (char *)malloc(mem_len);
}
strcat(cmd, argv[i]);
strcat(cmd, " ");
}
if (newline == 0)
usleep(225000);
for (i = 0; cmd[i]; i++)
ioctl (fd, TIOCSTI, cmd+i);
if (newline == 1)
ioctl (fd, TIOCSTI, nl);
close(fd);
free((void *)cmd);
exit (0);
}
使用sudo
权限编译并执行它。例如,如果要在/dev/pts/3
上执行命令,则只需执行sudo ./a.out -n /dev/pts/3 whoami
,在whoami
上运行/dev/pts/3
。
此代码完全取自this page。
答案 1 :(得分:0)
您似乎在命令周围使用了错误的引号。 删除引号和echo命令,或使用echo和back-ticks(`)。
尝试:
echo `date` > /dev/pts/3
或只是
date > /dev/pts/3
请注意,在/ dev / pts / 3上运行的任何内容都无法读取后面弹出的内容&#34;&#34;。