TTY로 위장한 프로그램 만들기
많은 시나리오에서 프로그램은 표준 입력의 특성을 면밀히 조사하여 터미널(TTY)인지 식별합니다. 또는 isatty와 같은 특수 기능을 사용하는 파이프입니다. 이러한 구별로 인해 프로그램은 출력을 다르게 생성하게 됩니다. 이 문제를 해결하기 위해 TTY로 가장할 수 있는 프로그램을 구성하는 방법을 살펴보겠습니다.
Linux 및 macOS용 솔루션
아래 코드 스니펫의 예는 다음과 같습니다. Linux와 macOS 모두를 위한 실행 가능한 솔루션입니다. pty 인터페이스를 활용하여 의사 터미널 내에서 명령을 실행하는 기능을 제공하여 프로그램을 효과적으로 속여 TTY에서 가져온 입력을 해석하도록 합니다.
#include <signal.h> #include <stdlib.h> #include <sysexits.h> #include <unistd.h> #include <util.h> pid_t child = 0; void sighandler(int signum) { if (child > 0) { killpg(child, signum); exit(signum); } } int main(int argc, char *argv[]) { if (argc < 2) { return EX_USAGE; } int master; child = forkpty(&master, NULL, NULL, NULL); // Forkpty setup: master (parent) and child (command execution) if (child == -1) { perror("failed to fork pty"); return EX_OSERR; } if (child == 0) { execvp(argv[1], argv + 1); // Execute the specified command within the pty } signal(SIGHUP, sighandler); signal(SIGINT, sighandler); signal(SIGTERM, sighandler); // Trap signals and forward them to the child const int buf_size = 1024; char buf[buf_size]; fd_set fds; ssize_t bytes_read; // I/O management variables while (1) { FD_ZERO(&fds); FD_SET(master, &fds); // Set up file descriptor set and monitor master (pty) if (select(master + 1, &fds, NULL, NULL, NULL) > 0 && FD_ISSET(master, &fds)) { bytes_read = read(master, buf, buf_size); if (bytes_read <= 0) { return EXIT_SUCCESS; } if (write(STDOUT_FILENO, buf, bytes_read) != bytes_read) { perror("failed to write to stdout"); return EX_OSERR; } } } }
이 코드는 상위 프로세스 간의 통신 채널을 설정합니다. pty 내에서 실행되는 하위 프로세스. 상위 프로세스는 지속적으로 pty에서 읽고 해당 내용을 stdout으로 전달하여 일반 TTY의 동작을 효과적으로 시뮬레이션합니다.
이 접근 방식을 구현하면 프로그램이 TTY의 입력을 기대하는 프로그램에 의해 부과된 잠재적 제약을 우회할 수 있습니다. 이를 통해 프로그램은 터미널의 모습을 그대로 유지하면서 입력을 조작하고 변환할 수 있습니다.
위 내용은 Linux 및 macOS에서 터미널(TTY)을 모방하는 프로그램을 어떻게 만들 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!