Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / Hosting / ISAPIApplicationHost.cs / 1 / ISAPIApplicationHost.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * Application host for IIS 5.0 and 6.0 * * Copyright (c) 1999 Microsoft Corporation */ namespace System.Web.Hosting { using Microsoft.Win32; using System.IO; using System.Text; using System.Web; using System.Web.Configuration; using System.Web.Util; using System.Web.Management; // helper class to implement AppHost based on ISAPI internal class ISAPIApplicationHost : MarshalByRefObject, IApplicationHost { private String _appId; private String _siteID; private String _siteName; private VirtualPath _virtualPath; private String _physicalPath; private IProcessHostSupportFunctions _functions; private const int MAX_PATH = 260; private const string LMW3SVC_PREFIX = "/LM/W3SVC/"; private const string DEFAULT_SITEID = "1"; private const string DEFAULT_APPID_PREFIX = "/LM/W3SVC/1/ROOT"; internal ISAPIApplicationHost(string appIdOrVirtualPath, string physicalPath, bool validatePhysicalPath, IProcessHostSupportFunctions functions) { // appIdOrVirtualPath is either a full metabase path, or just a virtual path // e.g. /LM/W3SVC/1/Root/MyApp ot /MyApp // Figure out which one we have, and get the other one from it _functions = functions; // make sure the functions are set in the default domain if (null == _functions) { ProcessHost h = ProcessHost.DefaultHost; if (null != h) { _functions = h.SupportFunctions; if (null != _functions) { HostingEnvironment.SupportFunctions = _functions; } } } IServerConfig serverConfig = ServerConfig.GetInstance(); if (StringUtil.StringStartsWithIgnoreCase(appIdOrVirtualPath, LMW3SVC_PREFIX)) { _appId = appIdOrVirtualPath; _virtualPath = VirtualPath.Create(ExtractVPathFromAppId(_appId)); _siteID = ExtractSiteIdFromAppId(_appId); _siteName = serverConfig.GetSiteNameFromSiteID(_siteID); } else { _virtualPath = VirtualPath.Create(appIdOrVirtualPath); _appId = GetDefaultAppIdFromVPath(_virtualPath.VirtualPathString); _siteID = DEFAULT_SITEID; _siteName = serverConfig.GetSiteNameFromSiteID(_siteID); } // Get the physical path from the virtual path if it wasn't passed in if (physicalPath == null) { _physicalPath = serverConfig.MapPath(this, _virtualPath); } else { _physicalPath = physicalPath; } if (validatePhysicalPath) { if (!Directory.Exists(_physicalPath)) { throw new HttpException(SR.GetString(SR.Invalid_IIS_app, appIdOrVirtualPath)); } } } internal ISAPIApplicationHost(string appIdOrVirtualPath, string physicalPath, bool validatePhysicalPath) :this(appIdOrVirtualPath, physicalPath, validatePhysicalPath, null) {} public override Object InitializeLifetimeService() { return null; // never expire lease } // IApplicationHost implementation string IApplicationHost.GetVirtualPath() { return _virtualPath.VirtualPathString; } String IApplicationHost.GetPhysicalPath() { return _physicalPath; } IConfigMapPathFactory IApplicationHost.GetConfigMapPathFactory() { return new ISAPIConfigMapPathFactory(); } IntPtr IApplicationHost.GetConfigToken() { if (null != _functions) { return _functions.GetConfigToken(_appId); } IntPtr token = IntPtr.Zero; String username; String password; IServerConfig serverConfig = ServerConfig.GetInstance(); bool hasUncUser = serverConfig.GetUncUser(this, _virtualPath, out username, out password); if (hasUncUser) { try { String error; token = IdentitySection.CreateUserToken(username, password, out error); } catch { } } return token; } String IApplicationHost.GetSiteName() { return _siteName; } String IApplicationHost.GetSiteID() { return _siteID; } void IApplicationHost.MessageReceived() { // make this method call a no-op // it will be removed soon altogether } internal string AppId { get { return _appId; } } private static String ExtractVPathFromAppId(string id) { // app id is /LM/W3SVC/1/ROOT for root or /LM/W3SVC/1/ROOT/VDIR // find fifth / (assuming it starts with /) int si = 0; for (int i = 1; i < 5; i++) { si = id.IndexOf('/', si+1); if (si < 0) break; } if (si < 0) // root? return "/"; else return id.Substring(si); } private static String GetDefaultAppIdFromVPath(string virtualPath) { if (virtualPath.Length == 1 && virtualPath[0] == '/') { return DEFAULT_APPID_PREFIX; } else { return DEFAULT_APPID_PREFIX + virtualPath; } } private static String ExtractSiteIdFromAppId(string id) { // app id is /LM/W3SVC/1/ROOT for root or /LM/W3SVC/1/ROOT/VDIR // the site id is right after prefix int offset = LMW3SVC_PREFIX.Length; int si = id.IndexOf('/', offset); return (si > 0) ? id.Substring(offset, si - offset) : DEFAULT_SITEID; } internal IProcessHostSupportFunctions SupportFunctions { get { return _functions; } } internal string ResolveRootWebConfigPath() { string rootWebConfigPath = null; if (null != _functions) { rootWebConfigPath = _functions.GetRootWebConfigFilename(); } return rootWebConfigPath; } } // // Create an instance of IConfigMapPath in the worker appdomain. // By making the class Serializable, the call to IConfigMapPathFactory.Create() // will execute in the worker appdomain. // [Serializable()] internal class ISAPIConfigMapPathFactory : IConfigMapPathFactory { IConfigMapPath IConfigMapPathFactory.Create(string virtualPath, string physicalPath) { return IISMapPath.GetInstance(); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * Application host for IIS 5.0 and 6.0 * * Copyright (c) 1999 Microsoft Corporation */ namespace System.Web.Hosting { using Microsoft.Win32; using System.IO; using System.Text; using System.Web; using System.Web.Configuration; using System.Web.Util; using System.Web.Management; // helper class to implement AppHost based on ISAPI internal class ISAPIApplicationHost : MarshalByRefObject, IApplicationHost { private String _appId; private String _siteID; private String _siteName; private VirtualPath _virtualPath; private String _physicalPath; private IProcessHostSupportFunctions _functions; private const int MAX_PATH = 260; private const string LMW3SVC_PREFIX = "/LM/W3SVC/"; private const string DEFAULT_SITEID = "1"; private const string DEFAULT_APPID_PREFIX = "/LM/W3SVC/1/ROOT"; internal ISAPIApplicationHost(string appIdOrVirtualPath, string physicalPath, bool validatePhysicalPath, IProcessHostSupportFunctions functions) { // appIdOrVirtualPath is either a full metabase path, or just a virtual path // e.g. /LM/W3SVC/1/Root/MyApp ot /MyApp // Figure out which one we have, and get the other one from it _functions = functions; // make sure the functions are set in the default domain if (null == _functions) { ProcessHost h = ProcessHost.DefaultHost; if (null != h) { _functions = h.SupportFunctions; if (null != _functions) { HostingEnvironment.SupportFunctions = _functions; } } } IServerConfig serverConfig = ServerConfig.GetInstance(); if (StringUtil.StringStartsWithIgnoreCase(appIdOrVirtualPath, LMW3SVC_PREFIX)) { _appId = appIdOrVirtualPath; _virtualPath = VirtualPath.Create(ExtractVPathFromAppId(_appId)); _siteID = ExtractSiteIdFromAppId(_appId); _siteName = serverConfig.GetSiteNameFromSiteID(_siteID); } else { _virtualPath = VirtualPath.Create(appIdOrVirtualPath); _appId = GetDefaultAppIdFromVPath(_virtualPath.VirtualPathString); _siteID = DEFAULT_SITEID; _siteName = serverConfig.GetSiteNameFromSiteID(_siteID); } // Get the physical path from the virtual path if it wasn't passed in if (physicalPath == null) { _physicalPath = serverConfig.MapPath(this, _virtualPath); } else { _physicalPath = physicalPath; } if (validatePhysicalPath) { if (!Directory.Exists(_physicalPath)) { throw new HttpException(SR.GetString(SR.Invalid_IIS_app, appIdOrVirtualPath)); } } } internal ISAPIApplicationHost(string appIdOrVirtualPath, string physicalPath, bool validatePhysicalPath) :this(appIdOrVirtualPath, physicalPath, validatePhysicalPath, null) {} public override Object InitializeLifetimeService() { return null; // never expire lease } // IApplicationHost implementation string IApplicationHost.GetVirtualPath() { return _virtualPath.VirtualPathString; } String IApplicationHost.GetPhysicalPath() { return _physicalPath; } IConfigMapPathFactory IApplicationHost.GetConfigMapPathFactory() { return new ISAPIConfigMapPathFactory(); } IntPtr IApplicationHost.GetConfigToken() { if (null != _functions) { return _functions.GetConfigToken(_appId); } IntPtr token = IntPtr.Zero; String username; String password; IServerConfig serverConfig = ServerConfig.GetInstance(); bool hasUncUser = serverConfig.GetUncUser(this, _virtualPath, out username, out password); if (hasUncUser) { try { String error; token = IdentitySection.CreateUserToken(username, password, out error); } catch { } } return token; } String IApplicationHost.GetSiteName() { return _siteName; } String IApplicationHost.GetSiteID() { return _siteID; } void IApplicationHost.MessageReceived() { // make this method call a no-op // it will be removed soon altogether } internal string AppId { get { return _appId; } } private static String ExtractVPathFromAppId(string id) { // app id is /LM/W3SVC/1/ROOT for root or /LM/W3SVC/1/ROOT/VDIR // find fifth / (assuming it starts with /) int si = 0; for (int i = 1; i < 5; i++) { si = id.IndexOf('/', si+1); if (si < 0) break; } if (si < 0) // root? return "/"; else return id.Substring(si); } private static String GetDefaultAppIdFromVPath(string virtualPath) { if (virtualPath.Length == 1 && virtualPath[0] == '/') { return DEFAULT_APPID_PREFIX; } else { return DEFAULT_APPID_PREFIX + virtualPath; } } private static String ExtractSiteIdFromAppId(string id) { // app id is /LM/W3SVC/1/ROOT for root or /LM/W3SVC/1/ROOT/VDIR // the site id is right after prefix int offset = LMW3SVC_PREFIX.Length; int si = id.IndexOf('/', offset); return (si > 0) ? id.Substring(offset, si - offset) : DEFAULT_SITEID; } internal IProcessHostSupportFunctions SupportFunctions { get { return _functions; } } internal string ResolveRootWebConfigPath() { string rootWebConfigPath = null; if (null != _functions) { rootWebConfigPath = _functions.GetRootWebConfigFilename(); } return rootWebConfigPath; } } // // Create an instance of IConfigMapPath in the worker appdomain. // By making the class Serializable, the call to IConfigMapPathFactory.Create() // will execute in the worker appdomain. // [Serializable()] internal class ISAPIConfigMapPathFactory : IConfigMapPathFactory { IConfigMapPath IConfigMapPathFactory.Create(string virtualPath, string physicalPath) { return IISMapPath.GetInstance(); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- InternalConfigConfigurationFactory.cs
- Subtract.cs
- ActivityTrace.cs
- AttachmentCollection.cs
- XPathException.cs
- TrackBarRenderer.cs
- NavigationProperty.cs
- CancellationTokenRegistration.cs
- TextTreeTextBlock.cs
- ValueHandle.cs
- GridItemPatternIdentifiers.cs
- BaseCAMarshaler.cs
- SchemaContext.cs
- RetriableClipboard.cs
- QueueProcessor.cs
- WebBrowserSiteBase.cs
- ResourceProviderFactory.cs
- MenuItemBinding.cs
- CodeDefaultValueExpression.cs
- CodeIterationStatement.cs
- QueryableFilterUserControl.cs
- BaseConfigurationRecord.cs
- srgsitem.cs
- XamlStyleSerializer.cs
- XmlEncApr2001.cs
- IfAction.cs
- Ray3DHitTestResult.cs
- shaperfactoryquerycacheentry.cs
- CharacterMetricsDictionary.cs
- OleDbReferenceCollection.cs
- TypedReference.cs
- UrlAuthorizationModule.cs
- Event.cs
- BitmapImage.cs
- CompilationLock.cs
- RegistryPermission.cs
- FixUp.cs
- AdRotator.cs
- httpapplicationstate.cs
- CRYPTPROTECT_PROMPTSTRUCT.cs
- MarshalByValueComponent.cs
- DateTimeFormatInfo.cs
- SQLMembershipProvider.cs
- DesignerDataStoredProcedure.cs
- DataGrid.cs
- DropDownList.cs
- UseAttributeSetsAction.cs
- SamlSerializer.cs
- SecondaryIndex.cs
- DecoderBestFitFallback.cs
- RIPEMD160Managed.cs
- CatalogZoneBase.cs
- BufferedGraphicsContext.cs
- PassportPrincipal.cs
- CollectionView.cs
- RtfFormatStack.cs
- GridViewUpdateEventArgs.cs
- ElementsClipboardData.cs
- OrderPreservingSpoolingTask.cs
- ContextStaticAttribute.cs
- x509store.cs
- ThrowOnMultipleAssignment.cs
- _SecureChannel.cs
- AttachmentCollection.cs
- CollectionView.cs
- Convert.cs
- QuotedPairReader.cs
- loginstatus.cs
- XmlDocumentSurrogate.cs
- IndexedString.cs
- _NegotiateClient.cs
- PageAdapter.cs
- TargetException.cs
- GridViewSortEventArgs.cs
- CursorInteropHelper.cs
- LineGeometry.cs
- CryptoConfig.cs
- UserInitiatedRoutedEventPermission.cs
- InitializationEventAttribute.cs
- DataServiceException.cs
- StylusTip.cs
- ProfileService.cs
- BaseCollection.cs
- ConstraintConverter.cs
- WCFServiceClientProxyGenerator.cs
- X509CertificateInitiatorClientCredential.cs
- MenuBase.cs
- CookieParameter.cs
- exports.cs
- BuildDependencySet.cs
- UnitySerializationHolder.cs
- DataGridColumn.cs
- SimpleHandlerBuildProvider.cs
- COAUTHIDENTITY.cs
- DataListGeneralPage.cs
- NativeMethods.cs
- CodeSnippetTypeMember.cs
- InvalidMessageContractException.cs
- FatalException.cs
- SqlProviderManifest.cs