我想在Linux系统上用C编写一个简单的X终端仿真器。
一开始,我只是想我必须弹出一个shell并显示其输出。我检查了xterm和rxvt代码,它看起来更加复杂。
首先,我必须使用openpty打开一个伪终端。因此,我看了手册页,发现openpty填充了两个文件描述符,即主文件和从文件。由于这些特殊文件的系统相关性,因此xterm和rxvt代码都很混乱。
我了解termios的内容:这只是关于终端的转义代码的一堆信息。我真正不明白的是:我应该如何处理主/从文件描述符?
打开终端,登录并在shell上执行“ ls”的示例程序非常棒。
(英语不是我的母语,请原谅我的最终错误)
编辑:这是我想出的示例代码:
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <pty.h>
#include <utmp.h>
#include <ctype.h>
void
safe_print (char* s)
{
while(*s) {
if(*s == '\n')
putchar("\n");
else if(iscntrl(*s))
printf("\\e(%d)", *s);
else
putchar(*s);
s++;
}
}
int
main (int argc, char** argv)
{
char buf[BUFSIZ] = {0};
int master;
int ret = forkpty(&master, NULL, NULL, NULL);
if(ret == -1)
puts("no fork"), exit(0);
if(!ret) {
execl("/bin/sh", "sh", NULL);
exit(0);
}
sleep(1); /* let the shell run */
if(argc >= 2) {
write(master, argv[1], strlen(argv[1]));
write(master, "\n", 1);
} else {
write(master, "date\n", sizeof "date\n");
}
while(1) {
switch(ret = read(master, buf, BUFSIZ)) {
case -1:
puts("error!");
exit(1);
break;
case 0:
puts("nothing.."), sleep(1);
break;
default:
buf[ret] = '\0';
safe_print(buf);
}
}
close(master);
return 0;
}
关于您问题的主/从部分,从pty(4)手册页(从我系统上的openpty(3)手册页引用):
伪终端是一对字符设备,一个主设备和一个从设备。从设备向进程提供与tty(4)中描述的接口相同的接口。但是,尽管提供tty(4)中描述的接口的所有其他设备在其后均具有某种硬件设备,但从设备却具有通过伪终端的上半部分操纵它的另一个过程。
即,写在主设备上的任何东西都作为输入提供给从设备,写在从设备上的任何东西都作为输入显示在主设备上。
手册页是您的朋友。
问题内容: 对于Google而言,这是不可能的,因为每个谈论和伪元素的文章似乎都使用“内容”一词。 我在这篇CSS-Tricks文章中听说过它,解释了如何实现图像滑块作为Web组件的示例用例。因此,它出现在内部的代码示例为: CSS HTML 似乎是指该标签,该标签用于允许用户包括Web组件,但我希望对此有更深入的了解。 编辑: 在进一步阅读之后,在上述文章中,我找到了作者的“ Shadow DO
问题内容: nix的含义是什么,它与Ruby有什么关系? 刚刚在一个采访问题中看到了这一点……我认为这与UNIX发行版有关,但我不确定。 在这里或在Wikipedia中找不到它,所以我问。 什么意思 ? 它与Ruby有什么关系?因为问题是关于Ruby的。 问题答案: nix仅表示类似于旧版Unix的操作系统。一些示例包括Linux,FreeBSD和Mac OS X(其内核Darwin基于BSD)。
这一章,我们来讲讲如何使用python做一个伪终端.不过在这之前你需要先了解一点伪终端的意思,还有一些技巧.这个我们会在下面讲到: 伪终端其实就是命令终端(cmd.exe,/bin/sh)通过网络接口反弹给攻击者,或者是新建一个监听端口反弹一个终端给攻击者,值得注意的就是原终端对于标准的输入,输出是不做处理的(stdin/stdout/stderr),同样的反弹的shell也是不对它做处理的.(s
为了减少内核或跨进程内存泄漏(Spectre攻击),Linux内核1将使用一个新选项编译,引入到,以便通过所谓的retpoline执行间接调用。 这似乎是一个新发明的术语,因为谷歌搜索只是最近才使用(通常都是在2018年)。 1但是,它不是Linux特有的--类似或相同的构造似乎被用作其他操作系统缓解策略的一部分。
我必须得到我使用ffmpeg的视频缩略图。在我的服务器上,我从ssh运行ffmpeg命令,然后它运行正常,但从php exec函数它不运行,它给出错误/usr/bin/ffmpeg:没有这样的文件或目录,但ffmpeg安装在这个位置usr/bin/ffmpeg。我的源代码是: 请提供任何解决方案。
问题内容: Java的drawImage()应该如何使用?我认为JDK文档不会很快到来。例如,所有drawImage签名都需要ImageObserver,但是有关此文档对新用户不是很有帮助。 问题答案: 您可以摆脱[或类似]。该参数是一个回调,用于通知您绘制操作的进度;并且仅在异步获取Image参数时才有用。 更清楚地说,如果调用未完全加载的Image,它将: 返回false(立即) 画出尽可能多