ASP.NET State Management. Slide 2 Lecture Overview Client state management options Cookies Server state management options Application state Session state.

Slides:



Advertisements
Similar presentations
7 Copyright © 2005, Oracle. All rights reserved. Maintaining State in J2EE Applications.
Advertisements

Not like the State of Virginia. What is State in ASP.NET? Services (like web services) are Stateless. This means if you make a second request to a server,
Current Popular IT I Pertemuan 10 Matakuliah: T0403/Current Popular IT I Tahun: 2008.
Maintaining State Between the Client and Server Internet Programming Using VBScript and JavaScript 9.
UFCE8V-20-3 Information Systems Development 3 (SHAPE HK)
Cookies, Sessions. Server Side Includes You can insert the content of one file into another file before the server executes it, with the require() function.
ASP.NET Best Practices Dawit Wubshet Park University.
Session 13 Active Server Pages (ASP) Matakuliah: M0114/Web Based Programming Tahun: 2005 Versi: 5.
CIS 451: ASP Sessions and Applications Dr. Ralph D. Westfall January, 2009.
Web Development in Microsoft Visual Studio Slide 2 Lecture Overview Introduce Visual Studio 2013 Create a first ASP.NET application.
Cookies.NET Security Summer 2006 CS795/895 Hadi Arbabi.
XP Tutorial 9 New Perspectives on JavaScript, Comprehensive1 Working with Cookies Managing Data in a Web Site Using JavaScript Cookies.
ASP.NET 2.0 Chapter 6 Securing the ASP.NET Application.
ASP.NET Programming with C# and SQL Server First Edition
 Mark Friedman Architect Developer Division Microsoft Corporation.
Web Development & Design Foundations with XHTML Chapter 9 Key Concepts.
Christopher M. Pascucci Basic Structural Concepts of.NET Browser – Server Interaction.
Form Handling, Validation and Functions. Form Handling Forms are a graphical user interfaces (GUIs) that enables the interaction between users and servers.
1 Web Developer & Design Foundations with XHTML Chapter 6 Key Concepts.
CHAPTER 12 COOKIES AND SESSIONS. INTRO HTTP is a stateless technology Each page rendered by a browser is unrelated to other pages – even if they are from.
CSC 2720 Building Web Applications Cookies, URL-Rewriting, Hidden Fields and Session Management.
IT533 Lectures Session Management in ASP.NET. Session Tracking 2 Personalization Personalization makes it possible for e-businesses to communicate effectively.
JavaScript, Fourth Edition
Advanced Web Forms with Databases Programming Right from the Start with Visual Basic.NET 1/e 13.
5 Chapter Five Web Servers. 5 Chapter Objectives Learn about the Microsoft Personal Web Server Software Learn how to improve Web site performance Learn.
Working with Cookies Managing Data in a Web Site Using JavaScript Cookies* *Check and comply with the current legislation regarding handling cookies.
Session 10: Managing State. Overview State Management Types of State Management Server-Side State Management Client-Side State Management The Global.asax.
© FPT SOFTWARE – TRAINING MATERIAL – Internal use 04e-BM/NS/HDCV/FSOFT v2/3 Managing State.
State Management. What is State management Why State management ViewState QueryString Cookies.
9 Chapter Nine Compiled Web Server Programs. 9 Chapter Objectives Learn about Common Gateway Interface (CGI) Create CGI programs that generate dynamic.
The Web Architecture and ASP.NET. Slide 2 Review of the Web (1) It began with HTTP and HTML, which delivers static Web pages to browsers which would render.
Chapter 8 Cookies And Security JavaScript, Third Edition.
Murach’s ASP.NET 4.0/VB, C1© 2006, Mike Murach & Associates, Inc.Slide 1.
Session tracking There are a number of problems that arise from the fact that HTTP is a "stateless" protocol. In particular, when you are doing on- line.
Maintaining State MacDonald Ch. 9 MIS 324 MIS 324 Professor Sandvig Professor Sandvig.
1 Maryland ColdFusion User Group Session Management December 2001 Michael Schuler
Chapter 6 Server-side Programming: Java Servlets
Cookies Web Browser and Server use HTTP protocol to communicate and HTTP is a stateless protocol. But for a commercial website it is required to maintain.
Dr. Azeddine Chikh IS444: Modern tools for applications development.
Christopher M. Pascucci Basic Structural Concepts of.NET Managing State & Scope.
Session and Cookie Management in.Net Sandeep Kiran Shiva UIN:
ASP.NET OPTIMIZATION. Why Optimize? $$$ Whether you build applications for customers or not, enhanced applications save money.
STATE MANAGEMENT.  Web Applications are based on stateless HTTP protocol which does not retain any information about user requests  The concept of state.
Slide 1 ASP Authentication There are basically three authentication modes Windows Passport Forms There are others through WCF You choose an authentication.
Module 7: Creating a Microsoft ASP.NET Web Application.
® IBM Software Group © 2007 IBM Corporation Best Practices for Session Management
Maintaining Application State MIS3502: Application Integration and Evaluation Paul Weinberg Presentation by David Schuff.
CSCI 6962: Server-side Design and Programming Java Server Faces Scoping and Session Handling.
ASP.Net, Web Forms and Web Controls 1 Outline Session Tracking Cookies Session Tracking with HttpSessionState.
The Problem of State. We will look at… Sometimes web development is just plain weird! Internet / World Wide Web Aspects of their operation The role of.
Understanding Web Applications Lesson 4. Objective Domain Matrix Skills/ConceptsMTA Exam Objectives Understanding Web Page Development Understand Web.
8 Chapter Eight Server-side Scripts. 8 Chapter Objectives Create dynamic Web pages that retrieve and display database data using Active Server Pages Process.
©SoftMooreSlide 1 Session Tracking with Servlets.
Active Server Pages Session - 3. Response Request ApplicationObjectContext Server Session Error ASP Objects.
ASP.NET Part II Dr. Awad Khalil Computer Science Department AUC.
Session 11: Cookies, Sessions ans Security iNET Academy Open Source Web Development.
HTTP Transactions 1. 2 Client-Server Model 3 HTTP HyperText Transport Protocol Native protocol for WWW Sits on top of internet’s TCP/IP protocol HTTP.
PHP: Further Skills 02 By Trevor Adams. Topics covered Persistence What is it? Why do we need it? Basic Persistence Hidden form fields Query strings Cookies.
ASP.NET Essentials State management, authentication, and Web Services Daniele Pagano Arizona State University.
ASP.NET State Management Overview Prepared By Manish Kumar Aery(IM66) Department of computer Application IET Bhaddal (Ropar)
111 State Management Beginning ASP.NET in C# and VB Chapter 4 Pages
Fundamentals of Web DevelopmentRandy Connolly and Ricardo HoarFundamentals of Web DevelopmentRandy Connolly and Ricardo Hoar Fundamentals of Web DevelopmentRandy.
Managing State Chapter 13.
State Management.
ASP.NET Caching.
Session management.
ASP.NET 4.0 State Management Improvements – Deep Dive
Building ASP.NET Applications
© 2016, Mike Murach & Associates, Inc.
PROFILE.
Presentation transcript:

ASP.NET State Management

Slide 2 Lecture Overview Client state management options Cookies Server state management options Application state Session state View state

Slide 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

Slide 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

Slide 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

Slide 6 Web Farm A single ASP.NET application is hosted on multiple web servers

Slide 7 Web Garden A single application pool contains multiple worker processes run across multiple CPUs

Slide 8 Client State Management (Introduction) View state Control state Hidden fields Cookies Query strings

Slide 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

Slide 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 While simple, it does add overhead in terms of page size MaxPageStateFieldLength controls the maximum page size

Slide 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

Slide 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

Slide 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

Slide 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

Slide 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

Slide 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

Slide 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

Slide 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

Slide 19 Server State Management Options Application state Session state Profile properties Database support

Slide 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

Slide 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

Slide 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

Slide 23 The HttpApplicationState Class (Members 2) StaticObjects returns a reference to objects declared in the global.asax file 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

Slide 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

Slide 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

Slide 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

Slide 27 Profiles (Enabling) Web.config must be modified to enable profiles You can then reference with code as follows

Slide 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

Slide 29 Session State (Configuration) The file contains a section The entries in this section configure the state client manager

Slide 30 Web.Config...

Slide 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

Slide 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

Slide 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

Slide 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

Slide 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

Slide 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