获取驱动程序证书链

[与此页面关联的功能 DirectShow 是一项旧功能。 它已被 MediaPlayerIMFMediaEngine媒体基金会中的音频/视频捕获取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能使用 MediaPlayerIMFMediaEngineMedia Foundation 中的音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]

若要将认证输出保护协议 (COPP) ,应用程序首先必须生成 DirectShow 图,其中包含视频混合渲染器筛选器 (VMR-7 或 VMR-9) 。 较旧的视频呈现器筛选器不支持 COPP。 在调用任何 COPP 方法之前,应用程序必须生成视频播放图并将解码器连接到 VMR 筛选器的输入引脚。 无需播放视频文件。

生成图形后,在 VMR 中查询 IAMCertifiedOutputProtection 接口,然后调用 IAMCertifiedOutputProtection::KeyExchange。 此方法返回一个键入为 GUID 的 128 位随机数,以及指向包含 UTF-8 格式的驱动程序 XML 证书链的字节数组的指针。 以下代码演示如何获取证书链。

GUID guidRandom;
BYTE *pbCertificateChain = NULL;
DWORD cbCertificateChainLen;   // Size of the certificate chain, in bytes.
hr = pCOPP->KeyExchange(&guidRandom, &pbCertificateChain,
         &cbCertificateChainLen);
if (SUCCEEDED(hr))
{
    // TODO: Validate the certificate chain and get the driver's
    // public key. 

    // When you are done, free the buffer that contains the 
    // certificate chain.
    CoTaskMemFree(pbCertificateChain);
}

使用认证输出保护协议 (COPP)