Die Neuerungen in ASP.NET 4.0 umfassen nur zwei neue Steuerelemente, aber viele gute Verbesserung an den bestehenden Steuerelementen und der Grundinfrastruktur.
  • Steuerelement Chart (bisher ein kostenfreies Add-on) ist enthalten.
  • Ein neues QueryExtender-Steuerelement zum Filtern in LinqDataSource und EntityDataSource.
  • Starke Verkleinerung der web.config-Dateien
  • Autostart Web Applications ("Preload"): Code der schon beim Starten des Webservers und nicht erst beim ersten Aufruf durch einen Benutzer gestartet wurd
  • Permanente Seitenumleitungen
  • Komprimierung des Sitzungszustands
  • Festlegung der erlaubten URLs
  • Einzelne Leistungsindikatoren für Webanwendungen in einem IIS Anwendungspool
  • Vereinfachtes Routing (URL Rewriting)
  • Neue Ausdruckssyntax für HTML-Zeichencodierung (HTML Encoded Code Expressions)
  • Festlegen der Metatags in Seitendirektive
  • Steuerung der Client-IDs
  • Bessere Steuerung des Seitenzustands (ViewState)
  • Persistente Auswahl in Listensteuerelementen GridView und ListView
  • Vereinfachungen beim ListView-Steuerelement durch möglichen Verzicht auf Layout Template.
  • Mehr Flexibilität bei Wizard und CreateUserWizard
  • Verbesserungen beim Rendering (Verzicht auf Inline Styles, <table>-Tags, CSS-Klasse für deaktivierte Steuerelemente, etc.)
  • Die neue abstrakte Basisklasse OutputCacheProvider erlaubt den Austausch des Seitenzwischen-speichermechanismus in ASP.NET
  • Die neue abstrakte Basisklasse HttpCapabilitiesProvider erlaubt die Festlegung von browser-spezifischen Eigenarten. Diese Klasse erbt interessanterweise nicht von ProviderBase. Eine Ablei-tung des HttpCapabilitiesProvider ist eine Alternative zu den .browser-Dateien, die es seit ASP.NET 2.0 gibt.
  • Die Klasse HttpEncoder kapselt die Codierung von Seitenzeichen in URL und HTML. HttpEnco-der wird verwendet von den Klassen HttpUtility, HttpServerUtility und HttpResponse-Header. Durch eine Ableitung dieser Klasse, die man in der web.config-Datei unter <httpRuntime encoderType="EigeneEncoderKlasse" /> einträgt, kann man den Mechanismus austauschen.
  • Seit ASP.NET 1.1 gibt es eine Überprüfung der HTTP-Anfragen gegen Cross-Site-Scripting-Angriffe (XSS). Auch hier enthält die neue Klasse RequestValidator die Standardimplementierung. Eine ab-geleitete Klasse kann man in <httpRuntime requestValidationTy-pe="EigeneValidierungsKlasse" /> eintragen.