SlideShare a Scribd company logo
ASP.NET
State Management
Presented BY
A.M Rajole
Lecture Overview
 Client state management options
 Cookies
 Server state management options
 Application state
 Session state
 View state
Introduction to State
Management
 Remember that ASP.NET (and the Web) is
stateless
 The Web server does not keep track of past
client requests
 Different technologies handle the issue of
statement management differently
 ASP.NET is somewhat unique in this regard
 But PHP works similarly
Types of State Management
 ASP.NET offers two categories of state
management
 Pure client-side statement management
 Server-side state management
 We can use both concurrently
State Management (Issues)
 Client state management consumes
bandwidth and introduces security risks
because sensitive data is passed back and
forth with each page postback
 Preserving state on a server can overburden
servers
 We also must consider Web farms and Web
gardens
Web Farm
 A single ASP.NET application is hosted on
multiple web servers
Web Garden
 A single application pool contains multiple
worker processes run across multiple CPUs
Client State Management
(Introduction)
 View state
 Control state
 Hidden fields
 Cookies
 Query strings
State Management
(ViewState)
 ViewState works in a couple of different
ways
 It’s managed for you automatically via the
ASP.NET infrastructure
 Or you can take control yourself via the
ViewState object
 ViewState only provides state for a single
page
 It won’t work with cross page postbacks or
other page transfers
State Management
(ViewState) (auto)
 Just enable ViewState and the corresponding
control retains is value from one postback to the next
 This happens by default
 You can disable ViewState at the page level
 <%@ Page EnableViewState=”false” %>
 While simple, it does add overhead in terms of page
size
 MaxPageStateFieldLength controls the
maximum page size
State Management
(ViewState) (manual)
 ViewState can be set on the server up to
the Page_PreRenderComplete event
 You can save any serializable object to
ViewState
 The information is really just saved in hidden
fields
 See example ViewState.aspx
State Management
(ControlState)
 The ControlState property allows you to
persist information as serialized data
 It’s used with custom controls (UserControl)
 The wiring is not automatic
 You must program the persisted data each
round trip
 The ControlState data is stored in hidden
fields
 More later when (if) we create a user control
State Management
(Hidden Fields)
 Use the HiddenField control to store
persisted data
 The data is stored in the Value property
 It’s simple and requires almost no server
resources
 It’s available from the ToolBox and works
much like a text box control
State Management (Cookies)
 Use to store small amounts of frequently
changed data
 Data is stored on the client’s hard disk
 A cookie is associated with a particular URL
 All data is maintained as client cookies
 Most frequently, cookies store personalization
information
Cookie Limitations
 While simple, cookies have disadvantages
 A cookie can only be 4096 bytes in size
 Most browsers restrict the total number of
cookies per site
 Users can refuse to accept cookies so don’t
try to use them to store critical information
Cookies Members
 Use the Response.Cookies collection to
reference a cookie
 Value contains the cookie’s value
 Expires contains the cookie’s expiration date
 Cookies can also store multiple values using
subkeys
 Similar to a QueryString
 It’s possible to restrict cookie scope by setting
the Path property to a folder
 See example cookies.aspx
State Management
(Query Strings)
 As you know, query strings are just strings
appended to a URL
 All browsers support them and no server
resources are required
State Management
(Query Strings)
 HttpContext.Current.Request.RawURL
gets a URL posted to the server
 Or just use Request.QueryString
 HttpUtility.ParseQueryString breaks
a query string into key / value pairs
 It returns a NameValueCollection
 We will see how to do this later when we
work more with query strings an URLs
Server State Management
Options
 Application state
 Session state
 Profile properties
 Database support
Server State Management
 HttpApplicationState applies to your
entire application
 Application object
 HttpSessionState applies to the
interaction between a user’s browser session
and your application
 Session object
 Page caching also relates to state
management
The Application’s State
(Introduction)
 An instance of the HttpApplicationState
object is created the first time a client
requests a page from a virtual directory
 Application state does not work in a Web farm
or Web garden scenario
 Unless we push data to a database
 It’s volatile – If the server crashes, the data is
gone
 Unless we persist out of process
 It’s really just a collection of key/value pairs
The HttpApplicationState
Class (Members 1)
 The AllKeys property returns an array of
strings containing all of the keys
 Count gets the number of objects in the
collection
 Item provides read/write access to the
collection
The HttpApplicationState
Class (Members 2)
 StaticObjects returns a reference to
objects declared in the global.asax file
 <object> tags with the scope set to
Application
 The Add method adds a new value to the
collection
 The Remove method removes the value
associated with a key
The HttpApplicationState
Class (Members 3)
 Lock and Unlock lock the collection,
respectively
 Not an ASP topic but a thread synchronization
topic
 Get returns the value of a collection item
 The item can be referenced by string key or
ordinal index
 Set store a value corresponding to the
specified key
 The method is thread safe
Application State
(Best Practices)
 Memory to store application state information
is permanently allocated
 You must write explicit code to release that
memory
 So don’t try to persist too much application state
information
 The Cache object, discussed later, provides
alternatives to storing application state
information
Profile Properties
 It’s a way to permanently store user-specific
data
 Data is saved to a programmer-defined data
store
 It takes quite a bit of programming
 The whole thing is unique to windows
 We will not use profiles in this course
Profiles (Enabling)
 Web.config must be modified to enable
profiles
 You can then reference with code as follows
Session State (Introduction)
 It is used to preserve state for a user’s
‘session’
 Session state works in Web farm or Web
garden scenarios
 Since the data is persisted in the page
 Session data can be stored in databases such
as SQL Server or Oracle making it persistent
 It’s very powerful and the features have been
significantly enhanced in ASP 2.0
Session State (Configuration)
 The <web.config> file contains a
<sessionState> section
 The entries in this section configure the state
client manager
Web.Config
<sessionState>
<sessionState mode="[Off|InProc|StateServer|SQLServer|Custom]"
timeout="number of minutes" cookieName="session identifier
cookie name" cookieless=
"[true|false|AutoDetect|UseCookies|UseUri|UseDeviceProfile]
" regenerateExpiredSessionId="[True|False]"
sqlConnectionString="sql connection string"
sqlCommandTimeout="number of seconds"
allowCustomSqlDatabase="[True|False]"
useHostingIdentity="[True|False]"
stateConnectionString="tcpip=server:port"
stateNetworkTimeout="number of seconds"
customProvider="custom provider name">
<providers>...</providers> </sessionState>
Session State Providers (1)
 Custom – State information is saved in a
custom data store
 InProc – State information is preserved in
the ASP.NET worker process named
(aspnet_wp.exe or w3wp.exe)
 This is the default option
 Off – Session state is disabled
Session State Providers (2)
 SQLServer – State data is serialized and
stored in an SQL server instance
 This might be a local or remote SQL Server
instance
 StateServer – State information is stored
in a separate state server process
(aspnet_state.exe)
 This process can be run locally or on another
machine
Session State Providers
(Best Practices)
 Use an SQL server provider to ensure that
session state is preserved
 Note that there is a performance hit here
because the session information is not stored in
the page
 The InProc provider is not perfect
 The ASP worker process might restart thereby
affecting session state
Session State Identifiers
 Browser sessions are identified with a unique
identifier stored in the SessionID property
 The SessionID is transmitted between the
browser and server via
 A cookie if cookies are enabled
 The URL if cookies are disabled
 Set the cookieless attribute to true in the
sessionState section of the Web.config file
HttpSessionState
(Members 1)
 CookieMode describes the application’s
configuration for cookieless sessions
 IsCookieless is used to depict whether
cookies are used to persist state
 IsNewSession denotes whether the session
was created with this request
 SessionID gets the unique ID associated
with this session
 Mode denotes the state client manager being
used
HttpSessionState
(Members 2)
 Timeout contains the number of minutes to
preserve state between requests
 Abandon sets an internal flag to cancel the
current session
 Add and Remove add or remove an item to
the session state
 Item reads/writes a session state value
 You can use a string key or ordinal index value
Thank You

More Related Content

PPTX
State management
PPSX
05 asp.net session07
PPT
Session viii(state mngtserver)
PPT
Session and state management
PPTX
81.pptx ajx fyjc semester paper 2 parrtens
DOCX
State management
PPS
05 asp.net session07
State management
05 asp.net session07
Session viii(state mngtserver)
Session and state management
81.pptx ajx fyjc semester paper 2 parrtens
State management
05 asp.net session07

Similar to StateManagement in ASP.Net.ppt (20)

PPSX
06 asp.net session08
PPT
State management
PPT
IEEE KUET SPAC presentation
PPT
2310 b 14
PPTX
ASP.NET Lecture 2
PPT
Session viii(state mngtclient)
PDF
C sharp and asp.net interview questions
PPSX
ASP.Net Presentation Part3
PPT
ASP.NET 12 - State Management
PDF
State Management In ASP.NET And ASP.NET MVC
PPTX
PPS
06 asp.net session08
PPTX
State management
PPS
05 asp.net session07
PPTX
Chapter 8 part2
PPT
MVC
PPTX
PPTX
Ch05 state management
PPTX
Introduction to ASP.NET
DOCX
Managing states
06 asp.net session08
State management
IEEE KUET SPAC presentation
2310 b 14
ASP.NET Lecture 2
Session viii(state mngtclient)
C sharp and asp.net interview questions
ASP.Net Presentation Part3
ASP.NET 12 - State Management
State Management In ASP.NET And ASP.NET MVC
06 asp.net session08
State management
05 asp.net session07
Chapter 8 part2
MVC
Ch05 state management
Introduction to ASP.NET
Managing states
Ad

More from charusharma165 (6)

PPTX
NETOverview1ppt.pptx
PPTX
Cartoon Training Courseware for Children.pptx
PPT
reiniforcement learning.ppt
PDF
ppt2.pdf
PPTX
JavaVariablesTypes.pptx
PPTX
Artificial_intelligence.pptx
NETOverview1ppt.pptx
Cartoon Training Courseware for Children.pptx
reiniforcement learning.ppt
ppt2.pdf
JavaVariablesTypes.pptx
Artificial_intelligence.pptx
Ad

Recently uploaded (20)

PPTX
chapter 3_bem.pptxKLJLKJLKJLKJKJKLJKJKJKHJH
PPTX
Job-opportunities lecture about it skills
PDF
esg-supply-chain-webinar-nov2018hkhkkh.pdf
PDF
シュアーイノベーション採用ピッチ資料|Company Introduction & Recruiting Deck
PDF
L-0018048598visual cloud book for PCa-pdf.pdf
PPTX
internship presentation of bsnl in colllege
PPTX
Your Guide to a Winning Interview Aug 2025.
PPTX
Nervous_System_Drugs_PPT.pptxXXXXXXXXXXXXXXXXX
PPTX
microtomy kkk. presenting to cryst in gl
PPTX
PMP (Project Management Professional) course prepares individuals
PPTX
The Stock at arrangement the stock and product.pptx
PDF
Prostaglandin E2.pdf orthoodontics op kharbanda
PPT
BCH3201 (Enzymes and biocatalysis)-JEB (1).ppt
PDF
MCQ Practice CBT OL Official Language 1.pptx.pdf
PPTX
Overview Planner of Soft Skills in a single ppt
PPTX
FINAL PPT.pptx cfyufuyfuyuy8ioyoiuvy ituyc utdfm v
PDF
Entrepreneurship PowerPoint for students
DOC
field study for teachers graduating samplr
PPTX
cse couse aefrfrqewrbqwrgbqgvq2w3vqbvq23rbgw3rnw345
PPTX
Autonomic_Nervous_SystemM_Drugs_PPT.pptx
chapter 3_bem.pptxKLJLKJLKJLKJKJKLJKJKJKHJH
Job-opportunities lecture about it skills
esg-supply-chain-webinar-nov2018hkhkkh.pdf
シュアーイノベーション採用ピッチ資料|Company Introduction & Recruiting Deck
L-0018048598visual cloud book for PCa-pdf.pdf
internship presentation of bsnl in colllege
Your Guide to a Winning Interview Aug 2025.
Nervous_System_Drugs_PPT.pptxXXXXXXXXXXXXXXXXX
microtomy kkk. presenting to cryst in gl
PMP (Project Management Professional) course prepares individuals
The Stock at arrangement the stock and product.pptx
Prostaglandin E2.pdf orthoodontics op kharbanda
BCH3201 (Enzymes and biocatalysis)-JEB (1).ppt
MCQ Practice CBT OL Official Language 1.pptx.pdf
Overview Planner of Soft Skills in a single ppt
FINAL PPT.pptx cfyufuyfuyuy8ioyoiuvy ituyc utdfm v
Entrepreneurship PowerPoint for students
field study for teachers graduating samplr
cse couse aefrfrqewrbqwrgbqgvq2w3vqbvq23rbgw3rnw345
Autonomic_Nervous_SystemM_Drugs_PPT.pptx

StateManagement in ASP.Net.ppt

  • 2. Lecture Overview  Client state management options  Cookies  Server state management options  Application state  Session state  View state
  • 3. Introduction to State Management  Remember that ASP.NET (and the Web) is stateless  The Web server does not keep track of past client requests  Different technologies handle the issue of statement management differently  ASP.NET is somewhat unique in this regard  But PHP works similarly
  • 4. Types of State Management  ASP.NET offers two categories of state management  Pure client-side statement management  Server-side state management  We can use both concurrently
  • 5. State Management (Issues)  Client state management consumes bandwidth and introduces security risks because sensitive data is passed back and forth with each page postback  Preserving state on a server can overburden servers  We also must consider Web farms and Web gardens
  • 6. Web Farm  A single ASP.NET application is hosted on multiple web servers
  • 7. Web Garden  A single application pool contains multiple worker processes run across multiple CPUs
  • 8. Client State Management (Introduction)  View state  Control state  Hidden fields  Cookies  Query strings
  • 9. State Management (ViewState)  ViewState works in a couple of different ways  It’s managed for you automatically via the ASP.NET infrastructure  Or you can take control yourself via the ViewState object  ViewState only provides state for a single page  It won’t work with cross page postbacks or other page transfers
  • 10. State Management (ViewState) (auto)  Just enable ViewState and the corresponding control retains is value from one postback to the next  This happens by default  You can disable ViewState at the page level  <%@ Page EnableViewState=”false” %>  While simple, it does add overhead in terms of page size  MaxPageStateFieldLength controls the maximum page size
  • 11. State Management (ViewState) (manual)  ViewState can be set on the server up to the Page_PreRenderComplete event  You can save any serializable object to ViewState  The information is really just saved in hidden fields  See example ViewState.aspx
  • 12. State Management (ControlState)  The ControlState property allows you to persist information as serialized data  It’s used with custom controls (UserControl)  The wiring is not automatic  You must program the persisted data each round trip  The ControlState data is stored in hidden fields  More later when (if) we create a user control
  • 13. State Management (Hidden Fields)  Use the HiddenField control to store persisted data  The data is stored in the Value property  It’s simple and requires almost no server resources  It’s available from the ToolBox and works much like a text box control
  • 14. State Management (Cookies)  Use to store small amounts of frequently changed data  Data is stored on the client’s hard disk  A cookie is associated with a particular URL  All data is maintained as client cookies  Most frequently, cookies store personalization information
  • 15. Cookie Limitations  While simple, cookies have disadvantages  A cookie can only be 4096 bytes in size  Most browsers restrict the total number of cookies per site  Users can refuse to accept cookies so don’t try to use them to store critical information
  • 16. Cookies Members  Use the Response.Cookies collection to reference a cookie  Value contains the cookie’s value  Expires contains the cookie’s expiration date  Cookies can also store multiple values using subkeys  Similar to a QueryString  It’s possible to restrict cookie scope by setting the Path property to a folder  See example cookies.aspx
  • 17. State Management (Query Strings)  As you know, query strings are just strings appended to a URL  All browsers support them and no server resources are required
  • 18. State Management (Query Strings)  HttpContext.Current.Request.RawURL gets a URL posted to the server  Or just use Request.QueryString  HttpUtility.ParseQueryString breaks a query string into key / value pairs  It returns a NameValueCollection  We will see how to do this later when we work more with query strings an URLs
  • 19. Server State Management Options  Application state  Session state  Profile properties  Database support
  • 20. Server State Management  HttpApplicationState applies to your entire application  Application object  HttpSessionState applies to the interaction between a user’s browser session and your application  Session object  Page caching also relates to state management
  • 21. The Application’s State (Introduction)  An instance of the HttpApplicationState object is created the first time a client requests a page from a virtual directory  Application state does not work in a Web farm or Web garden scenario  Unless we push data to a database  It’s volatile – If the server crashes, the data is gone  Unless we persist out of process  It’s really just a collection of key/value pairs
  • 22. The HttpApplicationState Class (Members 1)  The AllKeys property returns an array of strings containing all of the keys  Count gets the number of objects in the collection  Item provides read/write access to the collection
  • 23. The HttpApplicationState Class (Members 2)  StaticObjects returns a reference to objects declared in the global.asax file  <object> tags with the scope set to Application  The Add method adds a new value to the collection  The Remove method removes the value associated with a key
  • 24. The HttpApplicationState Class (Members 3)  Lock and Unlock lock the collection, respectively  Not an ASP topic but a thread synchronization topic  Get returns the value of a collection item  The item can be referenced by string key or ordinal index  Set store a value corresponding to the specified key  The method is thread safe
  • 25. Application State (Best Practices)  Memory to store application state information is permanently allocated  You must write explicit code to release that memory  So don’t try to persist too much application state information  The Cache object, discussed later, provides alternatives to storing application state information
  • 26. Profile Properties  It’s a way to permanently store user-specific data  Data is saved to a programmer-defined data store  It takes quite a bit of programming  The whole thing is unique to windows  We will not use profiles in this course
  • 27. Profiles (Enabling)  Web.config must be modified to enable profiles  You can then reference with code as follows
  • 28. Session State (Introduction)  It is used to preserve state for a user’s ‘session’  Session state works in Web farm or Web garden scenarios  Since the data is persisted in the page  Session data can be stored in databases such as SQL Server or Oracle making it persistent  It’s very powerful and the features have been significantly enhanced in ASP 2.0
  • 29. Session State (Configuration)  The <web.config> file contains a <sessionState> section  The entries in this section configure the state client manager
  • 30. Web.Config <sessionState> <sessionState mode="[Off|InProc|StateServer|SQLServer|Custom]" timeout="number of minutes" cookieName="session identifier cookie name" cookieless= "[true|false|AutoDetect|UseCookies|UseUri|UseDeviceProfile] " regenerateExpiredSessionId="[True|False]" sqlConnectionString="sql connection string" sqlCommandTimeout="number of seconds" allowCustomSqlDatabase="[True|False]" useHostingIdentity="[True|False]" stateConnectionString="tcpip=server:port" stateNetworkTimeout="number of seconds" customProvider="custom provider name"> <providers>...</providers> </sessionState>
  • 31. Session State Providers (1)  Custom – State information is saved in a custom data store  InProc – State information is preserved in the ASP.NET worker process named (aspnet_wp.exe or w3wp.exe)  This is the default option  Off – Session state is disabled
  • 32. Session State Providers (2)  SQLServer – State data is serialized and stored in an SQL server instance  This might be a local or remote SQL Server instance  StateServer – State information is stored in a separate state server process (aspnet_state.exe)  This process can be run locally or on another machine
  • 33. Session State Providers (Best Practices)  Use an SQL server provider to ensure that session state is preserved  Note that there is a performance hit here because the session information is not stored in the page  The InProc provider is not perfect  The ASP worker process might restart thereby affecting session state
  • 34. Session State Identifiers  Browser sessions are identified with a unique identifier stored in the SessionID property  The SessionID is transmitted between the browser and server via  A cookie if cookies are enabled  The URL if cookies are disabled  Set the cookieless attribute to true in the sessionState section of the Web.config file
  • 35. HttpSessionState (Members 1)  CookieMode describes the application’s configuration for cookieless sessions  IsCookieless is used to depict whether cookies are used to persist state  IsNewSession denotes whether the session was created with this request  SessionID gets the unique ID associated with this session  Mode denotes the state client manager being used
  • 36. HttpSessionState (Members 2)  Timeout contains the number of minutes to preserve state between requests  Abandon sets an internal flag to cancel the current session  Add and Remove add or remove an item to the session state  Item reads/writes a session state value  You can use a string key or ordinal index value