Como configurar o localizador de proxy
O aplicativo pode alterar a configuração padrão do localizador de proxy definindo a propriedade MFNETSOURCE_PROXYLOCATORFACTORY para o objeto de fábrica do localizador de proxy implementado pelo aplicativo. Quando o aplicativo chama métodos de resolvedor de origem para criar a fonte de rede, o Media Foundation chama o alocador do localizador de proxy. Esse objeto cria o localizador de proxy com configuração personalizada.
Para alterar a configuração padrão do localizador de proxy
- Implemente a interface IMFNetProxyLocatorFactory .
- No método IMFNetProxyLocatorFactory::CreateProxyLocator , faça o seguinte:
- Crie um repositório de propriedades.
- Defina as definições de configuração para o localizador de proxy. Para obter informações sobre essas configurações, consulte Configurações de configuração do localizador de proxy.
- Chame a função MFCreateProxyLocator . Passe o repositório de propriedades e o protocolo. O protocolo é especificado no parâmetro pszProtocol de CreateProxyLocator.
- Crie uma instância da classe de fábrica do localizador de proxy e obtenha um ponteiro para sua interface IMFNetProxyLocatorFactory .
- Crie outro repositório de propriedades e defina o valor da propriedade MFNETSOURCE_PROXYLOCATORFACTORY igual ao ponteiro IMFNetProxyLocatorFactory da etapa 3.
- Ao criar a fonte de rede, passe o repositório de propriedades no parâmetro pProps dos métodos de resolvedor de origem, como IMFSourceResolver::BeginCreateObjectFromURL.
Exemplo
O exemplo de código a seguir implementa a interface IMFNetProxyLocatorFactory . O método IMFNetProxyLocatorFactory::CreateProxyLocator cria uma instância do localizador de proxy padrão e o configura para operar no modo de detecção automática.
class CProxyLocatorFactory : public IMFNetProxyLocatorFactory
{
LONG m_cRef;
public:
CProxyLocatorFactory() : m_cRef(1)
{
}
STDMETHODIMP QueryInterface(REFIID riid, void** ppv)
{
static const QITAB qit[] =
{
QITABENT(CProxyLocatorFactory, IMFNetProxyLocatorFactory),
{ 0 }
};
return QISearch(this, qit, riid, ppv);
}
STDMETHODIMP_(ULONG) AddRef()
{
return InterlockedIncrement(&m_cRef);
}
STDMETHODIMP_(ULONG) Release()
{
LONG cRef = InterlockedDecrement(&m_cRef);
if (cRef == 0)
{
delete this;
}
return cRef;
}
STDMETHODIMP CreateProxyLocator(
LPCWSTR pszProtocol,
IMFNetProxyLocator **ppProxyLocator
)
{
*ppProxyLocator = NULL;
//Create the property store object
IPropertyStore *pProp = NULL;
HRESULT hr = PSCreateMemoryPropertyStore(IID_PPV_ARGS(&pProp));
if(SUCCEEDED(hr))
{
// Property key for proxy settings.
PROPERTYKEY key;
key.fmtid = MFNETSOURCE_PROXYSETTINGS;
key.pid = 0;
// Proxy settings
PROPVARIANT var;
var.vt = VT_I4;
var.lVal = MFNET_PROXYSETTING_AUTO;
hr = pProp->SetValue(key, var);
}
//Create the default proxy locator.
if(SUCCEEDED(hr))
{
hr = MFCreateProxyLocator(pszProtocol, pProp, ppProxyLocator);
}
SafeRelease(&pProp);
return hr;
}
};
O exemplo a seguir mostra como passar o ponteiro IMFNetProxyLocatorFactory para a origem da rede.
// Creates a media source from a URL.
//
// This example demonstrates how to set a proxy locator on the network source.
HRESULT CreateMediaSourceWithProxyLocator(
PCWSTR pszURL,
IMFMediaSource **ppSource
)
{
IPropertyStore *pConfig = NULL;
IMFNetProxyLocatorFactory *pFactory = new (std::nothrow) CProxyLocatorFactory();
if (pFactory == NULL)
{
return E_OUTOFMEMORY;
}
// Configure the property store.
HRESULT hr = PSCreateMemoryPropertyStore(IID_PPV_ARGS(&pConfig));
if (SUCCEEDED(hr))
{
PROPERTYKEY key;
key.fmtid = MFNETSOURCE_PROXYLOCATORFACTORY;
key.pid = 0;
PROPVARIANT var;
var.vt = VT_UNKNOWN;
var.punkVal = pFactory;
hr = pConfig->SetValue(key, var);
}
// Create the source media source.
if (SUCCEEDED(hr))
{
hr = CreateMediaSource(pszURL, pConfig, ppSource);
}
SafeRelease(&pConfig);
return hr;
}
Tópicos relacionados