Skip to main content

Asp.Net 4.0: An Overview-Part-III

This is the last post in the series which will explore the following new features of ASP.Net 4.0

  •  Performance Monitoring for Individual Applications in a Single Worker Process

  • Web.config File Refactoring

  • Permanently Redirecting a Page

  • Expanding the Range of Allowable URLs


Performance Monitoring for Individual Applications in a Single Worker Process

It is a common practice to host multiple ASP.NET applications in a single worker process, In order to increase the number of Web sites that can be hosted on a single server.

This practice results in difficulties for server administrators to identify an individual application that is experiencing problems.

ASP.NET 4 introduces new resource-monitoring functionality introduced by the CLR. To enable this functionality, following XML configuration snippet is added to the aspnet.config configuration file.(This file is located in the directory where the .NET Framework is installed )

<?xml version="1.0" encoding="UTF-8" ?>

<configuration>

<runtime>

   <appDomainResourceMonitoring enabled="true"/>

</runtime>

</configuration>

When the appDomainResourceMonitoring feature has been enabled, two new performance counters are available in the "ASP.NET Applications" performance category: Managed Processor Time and Managed Memory Used. With ASP.NET 4, administrators can now view into the resource consumption of individual applications running in a single worker process.

Web.config File Refactoring


In .the NET Framework 4, the major configuration elements have been moved to the machine.config file, and applications now inherit these settings. This allows the Web.config file in ASP.NET 4 applications either to be empty or to contain just the following lines, which specify for Visual Studio what version of the framework the application is targeting:

<?xml version="1.0"?>

<configuration>

<system.web>

<compilation targetFramework="4.0" />

</system.web>

</configuration> 

Permanently Redirecting a Page

 In Web applications pages and other content are moved around over time, which generally to stale links in search engines. To avoid this developers generally use Response.Redirect method to forward a request to the new URL.

What’s wrong with this approach?

The Redirect method issues an HTTP 302 Found (temporary redirect) response, which results in an extra HTTP round trip when users attempt to access the old URLs.

 What ASP.NET 4.0 offers

 ASP.NET 4 adds a new RedirectPermanent helper method that makes it easy to issue HTTP 301 (Moved Permanently) responses, as in the following example:

 RedirectPermanent ("/newpath/foroldcontent.aspx");

 What purpose does it serve?

 Search engines and other user agents that recognize permanent redirects will store the new URL that is associated with the content. It eliminates the unnecessary round trip made by the browser for temporary redirects.

 Expanding the Range of Allowable URLs

 

What is the Constraint in URL Length?

Prior to ASP.Net 4.0, URL path lengths could only be up to 260 characters. Seems like it’s enough for most of the URLs, but trust me and team mates who had a nightmarish experience when the URL length went way ahead of this limit, while implementing URL encryption for Proctor Management (and the only option that we had to follow was to change the encryption algorithm). There is a separate post for this, which can be read here.

 What does ASP.Net 4.0 Offer?

In ASP.NET 4, provides the option to increase (or decrease) the URL length limit as appropriate for the applications, using two new httpRuntime configuration attributes.

 The following example shows these new attributes.

<httpRuntime maxRequestPathLength="260" maxQueryStringLength="2048" />

 To allow longer or shorter paths (the portion of the URL that does not include protocol, server name, and query string), modify the maxRequestPathLength attribute.

To allow longer or shorter query strings, modify the value of the maxQueryStringLength attribute.

 Extending Allowable URLs

Prior to 4.0, ASP.Net the URL character checks were limited to a fixed set of characters

When ASP.NET finds an invalid character in the path portion of a URL, it rejects the request and issues an HTTP 400 error.

ASP.NET 4 also enables the developers to configure the characters that are used by the URL character check.The set of valid characters can be customized by  using the new requestPathInvalidChars attribute of the httpRuntime configuration element, as shown in the following example:

 <httpRuntime requestPathInvalidChars="&lt;,&gt;,*,%,&amp;,:,\,?" />

 By default, the requestPathInvalidChars attribute defines eight characters as invalid. (In the string that is assigned to requestPathInvalidChars by default, the less than (<), greater than (>), and ampersand (&) characters are encoded, because the Web.config file is an XML file

Note ASP.NET 4 always rejects URL paths that contain characters in the ASCII range of 0x00 to 0x1F.

This post concludes the series started for exploring Server Side enhancements in the ASP.Net 4.0.

This series is not exhaustive and a lot of other new features have been left out, that can be read from MSDN.

Hope this series was helpful,

Till Next we connect…..

Happy Learning!

Comments

Popular posts from this blog

Covariance and Contravariance-General Discussion

If you have just started the exploration of .Net Framework 4.0, two terms namely Covariance and Contravariance might have been heard. The concept that these terms encapsulate are used by most developer almost daily, however there has never been any botheration about the terminologies. Now, what actually these terms mean and how are these going to affect us as a developer, if we dive in to the details. The simple answer is it’s always good to know your tools before actually using them. Enough philosophy, let’s get to the business. Starting the discussion let me reiterate that in addition to Covariance and Contravariance, there is another terminology, Invariance. I’ll by start here by diving into the details of Invariance and then proceed further. Invariance: Invariance can be better understood by considering the types in .Net.>net has basically two type, value-types and reference-types. Value types (int, double etc) are invariant i.e. the types can’t be interchanged either ...

Advanced WCF

In this post, I am sharing the link of articles about  advanced topics in WCF. The List of articles is exhaustive and can serve as your repository for all WCF queries. Concurrency,Throttling & Callbacks  WCF Concurrency (Single, Multiple and Re entrant) and Throttling   WCF-Interop and BinarySecurityToken  WCF Callbacks  Creating Web Services From WSDL Link1 Link2 Link3 Link4 WCF-Security WCF over HTTPS   Transport Security(basic)/HTTPS UserNamePasswordValidator ServerCertificateValidationCallback 9 simple steps to enable X.509 certificates on WCF - CodeProject http://www.codeproject.com/KB/WCF/9StepsWCF.aspx?display=Print Message Security(Certificate)/PeerTrust Securing WCF Services with Certificates. - CodeProject http://www.codeproject.com/KB/WCF/wcf_certificates.aspx Message Security(Certificate)/ChainTrust How To Configure WCF Security Using Only X.509 Certificates - CodePr...