Compartir a través de


Desbloqueo del SDK de Windows Media Format

[La característica asociada a esta página, DirectShow, es una característica heredada. Se ha reemplazado por MediaPlayer, IMFMediaEngine y Captura de audio/vídeo en Media Foundation. Esas características se han optimizado para Windows 10 y Windows 11. Microsoft recomienda encarecidamente que el nuevo código use MediaPlayer, IMFMediaEngine y Audio/Video Capture en Media Foundation en lugar de DirectShow, siempre que sea posible. Microsoft sugiere que el código existente que usa las API heredadas se reescriba para usar las nuevas API si es posible.

Para acceder a la versión 7 o 7.1 del SDK de Windows Media Format, una aplicación debe proporcionar un certificado de software, también denominado clave, en tiempo de ejecución. Esta clave se encuentra en una biblioteca estática denominada wmstub.lib a la que se vincula la aplicación en tiempo de compilación. Solo se requiere una clave individualizada para crear o leer archivos protegidos con DRM. Los archivos que no son DRM se pueden crear mediante la biblioteca estática proporcionada con el SDK de Windows Media Format. Para obtener más información sobre cómo obtener la clave DRM, consulte el SDK de Windows Media Format. Una aplicación DirectShow proporciona su certificado al escritor asf de WM cuando se agrega al gráfico de filtros. La aplicación debe registrarse como proveedor de claves mediante las interfaces COM IServiceProvider e IObjectWithSite . Con esta técnica, la aplicación implementa una clase de proveedor de claves derivada de IServiceProvider. Esta clase implementa los tres métodos COM estándar (AddRef, QueryInterface y Release) junto con un método adicional, QueryService, al que llama el administrador de gráficos de filtros. QueryService llama al método del SDK de Windows Media Format WMCreateCertificate y vuelve al administrador de grafos de filtro un puntero al certificado que se creó. Si el certificado es válido, el administrador de gráficos de filtros permite que el proceso de creación de grafos continúe.

Nota:

Para compilar una aplicación, incluya Wmsdkidl.h para el prototipo de WMCreateCertificate y vincule a la biblioteca Wmstub.lib.

 

En el ejemplo de código siguiente se muestran los pasos básicos de este proceso:

// Declare and implement a key provider class derived from IServiceProvider.

class CKeyProvider : public IServiceProvider {
public:
    // IUnknown interface
    STDMETHODIMP QueryInterface(REFIID riid, void ** ppv);
    STDMETHODIMP_(ULONG) AddRef();
    STDMETHODIMP_(ULONG) Release();

    CKeyProvider();

    // IServiceProvider
    STDMETHODIMP QueryService(REFIID siid, REFIID riid, void **ppv);
    
private:
    ULONG m_cRef;
};

CKeyProvider::CKeyProvider() : m_cRef(0)
{
}

// IUnknown methods
ULONG CKeyProvider::AddRef()
{
    return InterlockedIncrement(&m_cRef);
}

ULONG CKeyProvider::Release()
{
    ASSERT(m_cRef > 0);

    ULONG lCount = InterlockedDecrement(&m_cRef);
    if (m_cRef == 0) 
    {
        delete this;
        return (ULONG)0;
    }
    return (ULONG)lCount;
}

// We only support IUnknown and IServiceProvider.
HRESULT CKeyProvider::QueryInterface(REFIID riid, void ** ppv)
{
    if (!ppv) return E_POINTER;

    if (riid == IID_IUnknown) 
    {
        *ppv = (void *) static_cast<IUnknown *>(this);
        AddRef();
        return S_OK;
    }
    if (riid == IID_IServiceProvider) 
    {
        *ppv = (void *) static_cast<IServiceProvider *>(this);
        AddRef();
        return S_OK;
    }

    return E_NOINTERFACE;
}

STDMETHODIMP CKeyProvider::QueryService(REFIID siid, REFIID riid, void **ppv)
{
    if (!ppv) return E_POINTER;

    if (siid == __uuidof(IWMReader) && riid == IID_IUnknown) 
    {
        IUnknown *punkCert;
        HRESULT hr = WMCreateCertificate(&punkCert);
        if (SUCCEEDED(hr)) 
        {
            *ppv = (void *) punkCert;
        }
        return hr;
    }
    return E_NOINTERFACE;
}

////////////////////////////////////////////////////////////////////
//
// These examples illustrate the sequence of method calls
// in your application. Error checking is omitted for brevity.
//
///////////////////////////////////////////////////////////////////

// Create the filter graph manager, but don't add any filters.
IGraphBuilder *pGraph;
hr = CreateFilterGraph(&pGraph);

...

// Instantiate the key provider class, and AddRef it
// so that COM doesn't try to free our static object.

CKeyProvider prov;
prov.AddRef();  // Don't let COM try to free our static object.

// Give the graph an IObjectWithSite pointer for callbacks and QueryService.
IObjectWithSite* pObjectWithSite = NULL;

hr = pGraph->QueryInterface(IID_IObjectWithSite, (void**)&pObjectWithSite);
if (SUCCEEDED(hr))
{
    // Use the IObjectWithSite pointer to specify our key provider object.
    // The filter graph manager will use this pointer to call
    // QueryService to do the unlocking.
    // If the unlocking succeeds, then we can build our graph.

    pObjectWithSite->SetSite((IUnknown *) (IServiceProvider *) &prov);
    pObjectWithSite->Release();
}

// Now build the graph.

Crear archivos ASF en DirectShow