Настройка указателя прокси-сервера
Приложение может изменить конфигурацию указателя прокси-сервера по умолчанию, задав для свойства MFNETSOURCE_PROXYLOCATORFACTORY объект фабрики указателя прокси-сервера, реализованный приложением. Когда приложение вызывает методы сопоставителя источника для создания сетевого источника, Media Foundation вызывает фабрику указателя прокси-сервера. Этот объект создает указатель прокси-сервера с настраиваемой конфигурацией.
Изменение параметра конфигурации по умолчанию указателя прокси-сервера
- Реализуйте интерфейс IMFNetProxyLocatorFactory .
- В методе IMFNetProxyLocatorFactory::CreateProxyLocator выполните следующие действия.
- Создайте хранилище свойств.
- Задайте параметры конфигурации для указателя прокси-сервера. Дополнительные сведения об этих параметрах см. в разделе Параметры конфигурации указателя прокси-сервера.
- Вызовите функцию MFCreateProxyLocator . Передайте хранилище свойств и протокол. Протокол указывается в параметре pszProtocolобъекта CreateProxyLocator.
- Создайте экземпляр класса фабрики указателя прокси-сервера и получите указатель на его интерфейс IMFNetProxyLocatorFactory .
- Создайте другое хранилище свойств и задайте значение свойства MFNETSOURCE_PROXYLOCATORFACTORY , равное указателю IMFNetProxyLocatorFactory из шага 3.
- При создании сетевого источника передайте хранилище свойств в параметре pProps методов сопоставителя источника, таких как IMFSourceResolver::BeginCreateObjectFromURL.
Пример
В следующем примере кода реализуется интерфейс IMFNetProxyLocatorFactory . Метод IMFNetProxyLocatorFactory::CreateProxyLocator создает экземпляр указателя прокси-сервера по умолчанию и настраивает его для работы в режиме автоматического обнаружения.
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;
}
};
В следующем примере показано, как передать указатель IMFNetProxyLocatorFactory в сетевой источник.
// 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;
}
Связанные темы