Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / Hosting / ISAPIApplicationHost.cs / 3 / 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. //------------------------------------------------------------------------------ //// 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.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ColumnMapProcessor.cs
- UnsafeNativeMethods.cs
- ResourcePropertyMemberCodeDomSerializer.cs
- BitmapEffectDrawingContextState.cs
- ToolboxItemCollection.cs
- PolicyConversionContext.cs
- HostingEnvironmentException.cs
- WindowsBrush.cs
- Attributes.cs
- KnownBoxes.cs
- ReliabilityContractAttribute.cs
- Ticks.cs
- TextDecorationCollection.cs
- OracleTimeSpan.cs
- CompoundFileStorageReference.cs
- LineGeometry.cs
- ViewStateException.cs
- SeverityFilter.cs
- Semaphore.cs
- WeakReference.cs
- _NestedSingleAsyncResult.cs
- RowCache.cs
- CompositionDesigner.cs
- PrivilegedConfigurationManager.cs
- CharacterString.cs
- XmlAttributeCollection.cs
- FormattedTextSymbols.cs
- SystemUnicastIPAddressInformation.cs
- Button.cs
- StringDictionaryWithComparer.cs
- DataGridViewCellCollection.cs
- CqlQuery.cs
- DesignerDataSourceView.cs
- Property.cs
- UInt64.cs
- BatchWriter.cs
- ReachVisualSerializerAsync.cs
- XmlILStorageConverter.cs
- RemotingServices.cs
- RightsManagementEncryptionTransform.cs
- ObjectStateEntryDbUpdatableDataRecord.cs
- RadioButton.cs
- XmlSchemaComplexContent.cs
- InternalTransaction.cs
- RotateTransform.cs
- SrgsGrammarCompiler.cs
- DictionarySectionHandler.cs
- IconBitmapDecoder.cs
- ExpressionVisitor.cs
- ItemTypeToolStripMenuItem.cs
- HighContrastHelper.cs
- StringAnimationUsingKeyFrames.cs
- TransportChannelListener.cs
- Sql8ExpressionRewriter.cs
- WebSysDescriptionAttribute.cs
- FormsAuthenticationUserCollection.cs
- documentsequencetextcontainer.cs
- Shape.cs
- DataBindingExpressionBuilder.cs
- TextInfo.cs
- ToolBarPanel.cs
- IteratorFilter.cs
- IDispatchConstantAttribute.cs
- CfgParser.cs
- ToolStripDropDownClosedEventArgs.cs
- HandleExceptionArgs.cs
- ResourcePermissionBaseEntry.cs
- CodeTypeReferenceSerializer.cs
- RegisteredDisposeScript.cs
- TypeDelegator.cs
- NameScope.cs
- ProviderSettings.cs
- AdapterUtil.cs
- XmlSchemaSet.cs
- DBNull.cs
- SystemIPGlobalStatistics.cs
- OrderedDictionary.cs
- XmlFormatExtensionPrefixAttribute.cs
- LogicalExpr.cs
- WmpBitmapEncoder.cs
- XmlRawWriterWrapper.cs
- ElasticEase.cs
- ScrollItemProviderWrapper.cs
- Registry.cs
- PrintPreviewGraphics.cs
- HostExecutionContextManager.cs
- CompilationLock.cs
- ClassHandlersStore.cs
- XLinq.cs
- SpellerInterop.cs
- Visual3DCollection.cs
- UInt64.cs
- TextElementCollectionHelper.cs
- SafeArrayTypeMismatchException.cs
- DesignerOptions.cs
- ConversionHelper.cs
- IdentityManager.cs
- ThrowOnMultipleAssignment.cs
- XslCompiledTransform.cs
- PreloadedPackages.cs