HOWTO: Retrieve the URL of a Web Page from an ActiveX ControlLast reviewed: February 25, 1998Article ID: Q181678 |
The information in this article applies to:
SUMMARYThis article demonstrates how an ActiveX control can retrieve the Uniform Resource Locator (URL) of the Web page (document) on which it is being hosted. This may be useful for restricting usage of an ActiveX control to a particular domain/site or accessing files when supplied a relative path.
MORE INFORMATIONDuring the initialization of an embedded ActiveX control, Internet Explorer (IE) passes a pointer to its client site by calling IOleObject::SetClientSite(). This process can be used to either retrieve a moniker for the container or access the document object model to retrieve the URL for the hosting Web page. This article demonstrates how to retrieve the current URL from the container moniker. For more information on how to obtain the URL from the document object model, please refer to the following article in the Microsoft Knowledge Base:
ARTICLE-ID: Q172763 TITLE : INFO: Accessing the Object Model from Within an ActiveX ControlFollow these steps to retrieve the current URL from the container moniker:
Sample Code
STDMETHOD(SetClientSite)(IOleClientSite *pClientSite) { if (pClientSite != NULL) { // Obtain URL from container moniker. CComPtr<IMoniker> spmk; LPOLESTR pszDisplayName; if (SUCCEEDED(pClientSite->GetMoniker( OLEGETMONIKER_TEMPFORUSER, OLEWHICHMK_CONTAINER, &spmk))) { if (SUCCEEDED(spmk->GetDisplayName( NULL, NULL, &pszDisplayName))) { USES_CONVERSION; CComBSTR bstrURL; bstrURL = pszDisplayName; ATLTRACE("The current URL is %s\n", OLE2T(bstrURL)); CoTaskMemFree((LPVOID)pszDisplayName); } } } return IOleObject_SetClientSite(pClientSite); } REFERENCESFor more information on the IOleObject, IoleClientSite, and IOleContainer interfaces, please refer to the Microsoft Visual C++ online help. (c) Microsoft Corporation 1998, All Rights Reserved. Contributions by Mark Davis, Microsoft Corporation Keywords : AXSDKControls Technology : internet ole Version : WINDOWS:1.0,3.0,3.01,3.02,4.0,4.01 Platform : WINDOWS Issue type : kbhowto |
================================================================================
© 1998 Microsoft Corporation. All rights reserved. Terms of Use. |