1

我有代码来检查带有“检测到 DRM 保护的流”的 STDERR:

const static char* DRM_TOKEN = "DRM protected stream detected";

const char* source = argv[1];
char tempfile[80];
memset(tempfile, 0, 80);
snprintf(tempfile, 80, "stderr_%lld.log", av_gettime());
freopen(tempfile, "w", stderr);

fflush(stderr);
FILE *fp = fopen(tempfile, "r");
if(fp)
{
    char STDERR[256];
    while(!feof(fp))
    {
    memset(STDERR, 0, sizeof(char) * 256);
    fgets(STDERR, 256, fp);
    if(strstr(STDERR, DRM_TOKEN) != NULL)
    {
        drm = 1;
        break ;
    }
    }
    fclose(fp);
}

它有效,但我想知道将 STDERR 读入 char[] 的任何直接方法。PS。我的代码将在 linux 或 macos 中运行。

4

1 回答 1

1

stderr"w"以只写模式重新打开。从您的av_gettime功能来看,您似乎正在使用libavcodec/ libavutil,因此您应该阅读av_log系统并注册您自己的日志记录功能以覆盖写入诊断消息的默认行为,而不是编写像这样的可怕黑客来获取错误消息到stderr.

于 2010-12-04T15:48:31.853 回答