当前位置:  开发笔记 > 编程语言 > 正文

你可以愚弄isatty并分别记录stdout和stderr吗?

如何解决《你可以愚弄isatty并分别记录stdout和stderr吗?》经验,为你挑选了2个好方法。

像这样?

% ./challenge.py >stdout 2>stderr
% cat stdout 
This is a real tty :)
standard output data
% cat stderr 
standard error data

因为我骗了一点.;-)

% echo $LD_PRELOAD
/home/karol/preload.so

像这样......

% gcc preload.c -shared -o preload.so -fPIC

我现在觉得很脏,但很有趣.:d

% cat preload.c
#include 

int isatty(int fd) {
    if(fd == 2 || fd == 1) {
        return 1;
    }
    return 0;
}

char* ttyname(int fd) {
    static char* fake_name = "/dev/fake";
    if(fd == 2 || fd == 1) {
        return fake_name;
    }
    return NULL;
}

是的,但Python应该是一个简化的挑战,而要解决的真正问题是二进制. (2认同)


Dima Tisnek.. 5

对于更简单的用例(例如开发测试),请使用strace(linux)或dtruss(OSX).当然,这在特权过程中不起作用.

这是一个示例,您可以将stdoutfd1与stderrfd2 区分开来:

$ strace -ewrite python2 test.py
[snip]
write(1, "This is a real tty :)\n", 22This is a real tty :)
) = 22
write(2, "standard error data", 19standard error data)     = 19
write(1, "standard output data", 20standard output data)    = 20
+++ exited with 0 +++

在上面的示例中,您看到每个standard xxx data加倍,因为您无法重定向stdout/stderr.但是,您可以要求strace将其输出保存到文件中.

在理论方面,如果stdout并且stderr引用同一个终端,则只能在进程的上下文中区分2,无论是在用户模式(LD_PRELOAD)还是内核空间(strace工具使用的ptrace接口).一旦数据到达实际设备,真实的伪,就会失去区别.



1> Karol Nowak..:

像这样?

% ./challenge.py >stdout 2>stderr
% cat stdout 
This is a real tty :)
standard output data
% cat stderr 
standard error data

因为我骗了一点.;-)

% echo $LD_PRELOAD
/home/karol/preload.so

像这样......

% gcc preload.c -shared -o preload.so -fPIC

我现在觉得很脏,但很有趣.:d

% cat preload.c
#include 

int isatty(int fd) {
    if(fd == 2 || fd == 1) {
        return 1;
    }
    return 0;
}

char* ttyname(int fd) {
    static char* fake_name = "/dev/fake";
    if(fd == 2 || fd == 1) {
        return fake_name;
    }
    return NULL;
}


是的,但Python应该是一个简化的挑战,而要解决的真正问题是二进制.

2> Dima Tisnek..:

对于更简单的用例(例如开发测试),请使用strace(linux)或dtruss(OSX).当然,这在特权过程中不起作用.

这是一个示例,您可以将stdoutfd1与stderrfd2 区分开来:

$ strace -ewrite python2 test.py
[snip]
write(1, "This is a real tty :)\n", 22This is a real tty :)
) = 22
write(2, "standard error data", 19standard error data)     = 19
write(1, "standard output data", 20standard output data)    = 20
+++ exited with 0 +++

在上面的示例中,您看到每个standard xxx data加倍,因为您无法重定向stdout/stderr.但是,您可以要求strace将其输出保存到文件中.

在理论方面,如果stdout并且stderr引用同一个终端,则只能在进程的上下文中区分2,无论是在用户模式(LD_PRELOAD)还是内核空间(strace工具使用的ptrace接口).一旦数据到达实际设备,真实的伪,就会失去区别.

推荐阅读
有风吹过best
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有