Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / State / SessionStateContainer.cs / 1 / SessionStateContainer.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HttpSessionState * * Copyright (c) 1998-1999, Microsoft Corporation * */ namespace System.Web.SessionState { using System.Threading; using System.Runtime.InteropServices; using System.Web; using System.Web.Util; using System.Collections; using System.Collections.Specialized; using System.Text; using System.Globalization; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class HttpSessionStateContainer : IHttpSessionState { String _id; ISessionStateItemCollection _sessionItems; HttpStaticObjectsCollection _staticObjects; int _timeout; bool _newSession; HttpCookieMode _cookieMode; SessionStateMode _mode; bool _abandon; bool _isReadonly; SessionStateModule _stateModule; // used for optimized InProc session id callback public HttpSessionStateContainer( String id, ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout, bool newSession, HttpCookieMode cookieMode, SessionStateMode mode, bool isReadonly) : this(null, id, sessionItems, staticObjects, timeout, newSession, cookieMode, mode, isReadonly) { if (id == null) { throw new ArgumentNullException("id"); } } internal HttpSessionStateContainer( SessionStateModule stateModule, string id, ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout, bool newSession, HttpCookieMode cookieMode, SessionStateMode mode, bool isReadonly) { _stateModule = stateModule; _id = id; // If null, it means we're delaying session id reading _sessionItems = sessionItems; _staticObjects = staticObjects; _timeout = timeout; _newSession = newSession; _cookieMode = cookieMode; _mode = mode; _isReadonly = isReadonly; } internal HttpSessionStateContainer() { } /* * The Id of the session. */ public String SessionID { get { if (_id == null) { Debug.Assert(_stateModule != null, "_stateModule != null"); _id = _stateModule.DelayedGetSessionId(); } return _id; } } /* * The length of a session before it times out, in minutes. */ public int Timeout { get {return _timeout;} set { if (value <= 0) { throw new ArgumentException(SR.GetString(SR.Timeout_must_be_positive)); } if (value > SessionStateModule.MAX_CACHE_BASED_TIMEOUT_MINUTES && (Mode == SessionStateMode.InProc || Mode == SessionStateMode.StateServer)) { throw new ArgumentException( SR.GetString(SR.Invalid_cache_based_session_timeout)); } _timeout = value; } } /* * Is this a new session? */ ////// public bool IsNewSession { get {return _newSession;} } /* * Is session state in a separate process */ ///[To be supplied.] ////// public SessionStateMode Mode { get {return _mode;} } /* * Is session state cookieless? */ public bool IsCookieless { get { if (_stateModule != null) { // See return _stateModule.SessionIDManagerUseCookieless; } else { // For container created by custom session state module, // sorry, we currently don't have a way to tell and thus we rely blindly // on cookieMode. return CookieMode == HttpCookieMode.UseUri; } } } public HttpCookieMode CookieMode { get {return _cookieMode;} } /* * Abandon the session. * */ ///[To be supplied.] ////// public void Abandon() { _abandon = true; } ///[To be supplied.] ////// public int LCID { // get { return Thread.CurrentThread.CurrentCulture.LCID; } set { Thread.CurrentThread.CurrentCulture = HttpServerUtility.CreateReadOnlyCultureInfo(value); } } ///[To be supplied.] ////// public int CodePage { // get { if (HttpContext.Current != null) return HttpContext.Current.Response.ContentEncoding.CodePage; else return Encoding.Default.CodePage; } set { if (HttpContext.Current != null) HttpContext.Current.Response.ContentEncoding = Encoding.GetEncoding(value); } } public bool IsAbandoned { get {return _abandon;} } public HttpStaticObjectsCollection StaticObjects { get { return _staticObjects;} } public Object this[String name] { get { return _sessionItems[name]; } set { _sessionItems[name] = value; } } ///[To be supplied.] ////// public Object this[int index] { get {return _sessionItems[index];} set {_sessionItems[index] = value;} } ///[To be supplied.] ////// public void Add(String name, Object value) { _sessionItems[name] = value; } ///[To be supplied.] ////// public void Remove(String name) { _sessionItems.Remove(name); } ///[To be supplied.] ////// public void RemoveAt(int index) { _sessionItems.RemoveAt(index); } ///[To be supplied.] ////// public void Clear() { _sessionItems.Clear(); } ///[To be supplied.] ////// public void RemoveAll() { Clear(); } ///[To be supplied.] ////// public int Count { get {return _sessionItems.Count;} } ///[To be supplied.] ////// public NameObjectCollectionBase.KeysCollection Keys { get {return _sessionItems.Keys;} } ///[To be supplied.] ////// public IEnumerator GetEnumerator() { return _sessionItems.GetEnumerator(); } ///[To be supplied.] ////// public void CopyTo(Array array, int index) { for (IEnumerator e = this.GetEnumerator(); e.MoveNext();) array.SetValue(e.Current, index++); } ///[To be supplied.] ////// public Object SyncRoot { get { return this;} } ///[To be supplied.] ////// public bool IsReadOnly { get { return _isReadonly;} } ///[To be supplied.] ////// public bool IsSynchronized { get { return false;} } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ //[To be supplied.] ///// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HttpSessionState * * Copyright (c) 1998-1999, Microsoft Corporation * */ namespace System.Web.SessionState { using System.Threading; using System.Runtime.InteropServices; using System.Web; using System.Web.Util; using System.Collections; using System.Collections.Specialized; using System.Text; using System.Globalization; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class HttpSessionStateContainer : IHttpSessionState { String _id; ISessionStateItemCollection _sessionItems; HttpStaticObjectsCollection _staticObjects; int _timeout; bool _newSession; HttpCookieMode _cookieMode; SessionStateMode _mode; bool _abandon; bool _isReadonly; SessionStateModule _stateModule; // used for optimized InProc session id callback public HttpSessionStateContainer( String id, ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout, bool newSession, HttpCookieMode cookieMode, SessionStateMode mode, bool isReadonly) : this(null, id, sessionItems, staticObjects, timeout, newSession, cookieMode, mode, isReadonly) { if (id == null) { throw new ArgumentNullException("id"); } } internal HttpSessionStateContainer( SessionStateModule stateModule, string id, ISessionStateItemCollection sessionItems, HttpStaticObjectsCollection staticObjects, int timeout, bool newSession, HttpCookieMode cookieMode, SessionStateMode mode, bool isReadonly) { _stateModule = stateModule; _id = id; // If null, it means we're delaying session id reading _sessionItems = sessionItems; _staticObjects = staticObjects; _timeout = timeout; _newSession = newSession; _cookieMode = cookieMode; _mode = mode; _isReadonly = isReadonly; } internal HttpSessionStateContainer() { } /* * The Id of the session. */ public String SessionID { get { if (_id == null) { Debug.Assert(_stateModule != null, "_stateModule != null"); _id = _stateModule.DelayedGetSessionId(); } return _id; } } /* * The length of a session before it times out, in minutes. */ public int Timeout { get {return _timeout;} set { if (value <= 0) { throw new ArgumentException(SR.GetString(SR.Timeout_must_be_positive)); } if (value > SessionStateModule.MAX_CACHE_BASED_TIMEOUT_MINUTES && (Mode == SessionStateMode.InProc || Mode == SessionStateMode.StateServer)) { throw new ArgumentException( SR.GetString(SR.Invalid_cache_based_session_timeout)); } _timeout = value; } } /* * Is this a new session? */ ////// public bool IsNewSession { get {return _newSession;} } /* * Is session state in a separate process */ ///[To be supplied.] ////// public SessionStateMode Mode { get {return _mode;} } /* * Is session state cookieless? */ public bool IsCookieless { get { if (_stateModule != null) { // See return _stateModule.SessionIDManagerUseCookieless; } else { // For container created by custom session state module, // sorry, we currently don't have a way to tell and thus we rely blindly // on cookieMode. return CookieMode == HttpCookieMode.UseUri; } } } public HttpCookieMode CookieMode { get {return _cookieMode;} } /* * Abandon the session. * */ ///[To be supplied.] ////// public void Abandon() { _abandon = true; } ///[To be supplied.] ////// public int LCID { // get { return Thread.CurrentThread.CurrentCulture.LCID; } set { Thread.CurrentThread.CurrentCulture = HttpServerUtility.CreateReadOnlyCultureInfo(value); } } ///[To be supplied.] ////// public int CodePage { // get { if (HttpContext.Current != null) return HttpContext.Current.Response.ContentEncoding.CodePage; else return Encoding.Default.CodePage; } set { if (HttpContext.Current != null) HttpContext.Current.Response.ContentEncoding = Encoding.GetEncoding(value); } } public bool IsAbandoned { get {return _abandon;} } public HttpStaticObjectsCollection StaticObjects { get { return _staticObjects;} } public Object this[String name] { get { return _sessionItems[name]; } set { _sessionItems[name] = value; } } ///[To be supplied.] ////// public Object this[int index] { get {return _sessionItems[index];} set {_sessionItems[index] = value;} } ///[To be supplied.] ////// public void Add(String name, Object value) { _sessionItems[name] = value; } ///[To be supplied.] ////// public void Remove(String name) { _sessionItems.Remove(name); } ///[To be supplied.] ////// public void RemoveAt(int index) { _sessionItems.RemoveAt(index); } ///[To be supplied.] ////// public void Clear() { _sessionItems.Clear(); } ///[To be supplied.] ////// public void RemoveAll() { Clear(); } ///[To be supplied.] ////// public int Count { get {return _sessionItems.Count;} } ///[To be supplied.] ////// public NameObjectCollectionBase.KeysCollection Keys { get {return _sessionItems.Keys;} } ///[To be supplied.] ////// public IEnumerator GetEnumerator() { return _sessionItems.GetEnumerator(); } ///[To be supplied.] ////// public void CopyTo(Array array, int index) { for (IEnumerator e = this.GetEnumerator(); e.MoveNext();) array.SetValue(e.Current, index++); } ///[To be supplied.] ////// public Object SyncRoot { get { return this;} } ///[To be supplied.] ////// public bool IsReadOnly { get { return _isReadonly;} } ///[To be supplied.] ////// public bool IsSynchronized { get { return false;} } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.[To be supplied.] ///
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ConfigurationManagerInternalFactory.cs
- ConnectionPointCookie.cs
- ColumnHeaderConverter.cs
- PartialClassGenerationTask.cs
- ModelVisual3D.cs
- HtmlSelect.cs
- SortedDictionary.cs
- NativeMethods.cs
- Triplet.cs
- LocalizationComments.cs
- FrameworkTemplate.cs
- GatewayIPAddressInformationCollection.cs
- LinearGradientBrush.cs
- HttpWebRequest.cs
- DetectEofStream.cs
- RawTextInputReport.cs
- ImpersonateTokenRef.cs
- MessageDecoder.cs
- SqlTrackingQuery.cs
- XsltSettings.cs
- Compilation.cs
- TabletCollection.cs
- Quad.cs
- MenuTracker.cs
- FlowDocumentReader.cs
- TextEditorMouse.cs
- XamlToRtfWriter.cs
- SqlConnectionPoolProviderInfo.cs
- PageVisual.cs
- DateTimeConverter.cs
- EditCommandColumn.cs
- SafeArrayRankMismatchException.cs
- EventWaitHandleSecurity.cs
- RightsManagementPermission.cs
- HttpMethodConstraint.cs
- LabelAutomationPeer.cs
- XmlBaseReader.cs
- Model3D.cs
- InputScopeAttribute.cs
- ProviderConnectionPointCollection.cs
- DesignerVerbToolStripMenuItem.cs
- CommandHelpers.cs
- SafeNativeMethods.cs
- ToolStripScrollButton.cs
- ButtonBase.cs
- TextTreeFixupNode.cs
- ConsoleCancelEventArgs.cs
- DesignerDataConnection.cs
- MaxValueConverter.cs
- ServiceModelConfigurationElementCollection.cs
- XmlIlGenerator.cs
- DataBindingHandlerAttribute.cs
- XmlSchemaDatatype.cs
- Tracking.cs
- CachingHintValidation.cs
- DocumentSequence.cs
- ListenerElementsCollection.cs
- Expressions.cs
- ACE.cs
- ProfileProvider.cs
- HMACMD5.cs
- ButtonChrome.cs
- StaticSiteMapProvider.cs
- Oid.cs
- PackageRelationshipSelector.cs
- HttpRuntimeSection.cs
- TransferMode.cs
- SimpleTypesSurrogate.cs
- PropertyExpression.cs
- TargetControlTypeAttribute.cs
- control.ime.cs
- errorpatternmatcher.cs
- IgnoreSectionHandler.cs
- SqlEnums.cs
- _FixedSizeReader.cs
- Thread.cs
- SortDescription.cs
- MediaPlayer.cs
- FillRuleValidation.cs
- TileBrush.cs
- Guid.cs
- Int32EqualityComparer.cs
- PageCatalogPart.cs
- GridProviderWrapper.cs
- FileSystemInfo.cs
- Match.cs
- NativeActivityAbortContext.cs
- OdbcCommand.cs
- NavigationProperty.cs
- ToolStripDropDown.cs
- TrackingValidationObjectDictionary.cs
- CodeAccessSecurityEngine.cs
- BackStopAuthenticationModule.cs
- AmbiguousMatchException.cs
- XmlTextReaderImplHelpers.cs
- ExpressionEditorAttribute.cs
- HwndSourceParameters.cs
- AppModelKnownContentFactory.cs
- SingleObjectCollection.cs
- followingquery.cs