Tuesday, November 22, 2011

ASP.Net State management

What is State Management?
State management is the process by which you maintain state and page information over multiple requests for the same or different pages.
ASP.NET includes several options that help you preserve data on both a per-page basis and an application-wide basis.

Types of State Management
There are two basic types of State Management:
1.       Client-Based State Management
2.       Server-Based State Management
Client-Based State Management:
Client based state management techniques stores data on the client in various ways. Client based state management techniques are:
A.      View state
B.      Control state
C.      Hidden fields
D.      Cookies
E.       Query strings
View state:
The view state represents the state of the page when it was last processed on the server. It's used to build a call context and retain values across two successive requests for the same page. By default, the state is persisted on the client using a hidden field added to the page and is restored on the server before the page request is processed.
If the amount of data stored in the ViewState() property exceeds the specified value in the MaxPageStateFieldLength() property, multiple hidden fields are used to store View state data.
                Advantages:     
a)      Server resources not required.
b)      Simple implementation
c)       automatic retention of page and control state
d)      Enhanced security features. The values in view state are hashed, compressed, and encoded for Unicode implementations.
Disadvantages:
a)      Scope is limited to only single page.
b)      Performance. The view state is stored in the page itself, so increase the page size.
c)       Security. The view state is stored in a hidden field on the page. Although view state stores data in a hashed format, it can be tampered with. 
Control state:
If you create a custom control that requires view state to work properly, you should use control state to ensure your control work properly though developers disable view state. The ControlState() property allows you to persist property information that is specific to a control and cannot be turned off like the ViewState() property.
     Advantages:     
a)      Server resources not required.
b)      Reliable. Because control state can not be turned off like ViewState.

Disadvantages:
a)      Some programming is required.
Hidden Fields:
A hidden field acts as a repository for any page-specific information that you want to store directly in the page. ASP.NET allows you to store information in a HiddenField control, which renders as a standard HTML hidden field. A hidden field does not render visibly in the browser.
You must submit the page using an HTTP POST command in order for hidden-field values to be available.

                Advantages:     
a)      Server resources not required.
b)      Simple implementation
c)       Widespread support.
Disadvantages:
a)      Potential security risk.
b)      Performance. The hidden fields are stored in the page itself, so increase the page size.
c)       Does not support rich data types to store.
Cookies:
A cookie is a small amount of data that is stored either in a text file on the client file system or in-memory in the client browser session. Browser sends with cookies values with every page request to the same server. Cookies can be temporary or persistent.

Advantages:     
a)      Server resources not required.
b)      Simple implementation
c)       Configurable expiration rules
d)      Data persistent.
Disadvantages:
e)      Size limitation: Most browsers support maximum 4096 bytes cookies.
f)       User configuration refusal: User can disable cookies in their browser.
g)      Security risk: Can be tempered.  
Query strings:
A query string is information that is appended to the end of a page URL. Query strings provide a simple but limited way to maintain state information.  Some browsers and client devices impose a 2083 character limit on the length of the URL.
You must submit the page using an HTTP POST command in order for query string values to be available.
Advantages:     
h)      Server resources not required.
i)        Simple implementation
j)        Widespread support.
Disadvantages:
k)      Size limitation: Some browser limits 2083 chars on the length of URLs.
l)        Security risk: Information is visible to the user.  
Server-Based State Management:
Server based state management techniques store data in memory on the server.  Server based state management techniques are:
A.      Application state
B.      Session state
C.      Profile Properties
Application state:
Application state provides a method of storing data global to whole application. These data are visible to entire application and shared by all active sessions. That’s why Application state variables are global variables for an ASP.Net application.
Advantages:     
m)    Simple implementation
n)      Application wide scope
Disadvantages:
o)      Application scope in case of Web Garden or Web Firm.
p)      Limited Durability of data.
q)      Requires server memory.
Session state:
Session state provides a method of storing session specific information that is visible only within the session.
Advantages:     
r)       Simple implementation
s)       Session specific events
t)       Data can persists across multiple process
Disadvantages:
u)      Application scope
v)      Limited Durability of data.
w)    Requires server memory

Wednesday, November 16, 2011

How can I improve performance and speed of my asp.net web application?

This is a most frequently asked question in asp.net communities. I will list out some points that are important to speed up asp.net web application.
  1. Always use Page.IsValid property. Page.IsValid confirms that all validation controls in page returns valid. Execute server side code only when page is valdated.
  2. Use Page.IsPostBack property to minimize redundant processing. Confirm that only data is loaded on first time page load.
  3. Use HttpServerUtility.Transfer method.
  4. Use StringBuilder for large string manipulation. Strings are immutable. The large is string operation you need the more benefit you can get from StringBuilder.
  5. Avoid unnecessary type conversions. Type casting is costly so do it only when necessary.
  6. Use ViewState only when necessary. Use of ViewState increase page size which increase traffic load on network.
  7. Restrict use of Session state. Use of Session and Application state directly have affect on server memory. 
  8. Remove unnecessary using’s.
  9. Build your application on Release mode. Release mode avoid including debug information which increase execution of application.
  10. Precompile your Application.
  11. Use Asp.Net Caching.
  12. Enable buffering. 
  13. Use transaction properly. 
  14. Limit use of Asp.Net Server controls.
  15. Use client side validation.
  16. Don’t rely on Exception.
  17. Use finally block to dispose unnecessary objects.
  18. Avoid unnecessary round trip to the server.
  19. Avoid Use of ViewState encryption unless necessary.
  20. Disable Debug mode.
  21. Rewrite call incentive COM components in managed code.
  22. Avoid blocking and long running tasks.
  23. Take advantage of HttpResponse.IsClientConnect before performing large operation.
  24. Optimize extensive loops. for loop is faster than foreach loop. Use for loop where possible.
  25. Avoid using deep hierarchy of controls.
  26. Avoid using Page.DataBind.
  27. Minimize calling DataBinder.Eval.
  28. Use Repeater when you need to display read only data.
  29. Consider using ListView instead of GridView.
  30. Use Response.Write for formatting output.
  31. Use paging properly for large result sets. ListView or GridView that may contain more than 20 rows should have paging allowed.
  32. Use SSL only for pages that require it.
  33. Disable tracing and debugging.
  34. Consider using HTTP compression.
  35. Reduce No of HTTP requests.
  36. Removed unnecessary white space from page.
  37. Avoid MS Ajax, Consider using light weight java script library like JQuery, ExtJs etc.
  38. Use index on all foreign keys.
  39. Minimize use of cursor.
  40. Minify JS files while deploying.
  41. Put CSS on top of page.
  42. Put JS on bottom of page.
  43. Make css and java script files external.
  44. Use Content Deliver Network for static content.
  45. Consider CSS and Image sprite to reduce number of request. 
  46. Do not scale image in HTML.
  47. Batch SQL Statement to reduce round trip.
  48. Use SETNOCOUNT ON in stored procedure.
  49. Use SET TRANSACTION ISOLATION LEVEL READ COMMITTED below SETNOCOUNT ON and before SELECT queries to ensure no locks during reads.
  50. Consider index on columns used in Where, Order by, Group by and Distinct clause.
  51. Use Stored Procedure for Data Access.
  52. Use DataReader class for fast forward only data cursor.
  53. Rewrite inefficient queries to improve performance.
  54. Write paged queries to ensure that you retrieve only required data from database.
  55. Consider using connection pooling.

Thanks

Sunday, September 25, 2011

Sending email with embeded image

I have written some articles on sending email from .net application. In this article I will show you a tricky way of sending embeded image to your mail.

The trick to embed image is to create an alternative view and to add a linked resource to the alternative view. Alternative views enable you to create different versions of the email message -- typically one in plain text and the other formatted with HTML. These then substitute for the basic msg.Body property.

To do the actual embedding, you need to do a number of things:
  • Create an HTML-formatted message.
  • Use an <img> tag in the message body.
  • For the src attribute of the <img>, point to a content ID (cid). This points to the portion of the message containing the image stream.
  • Create an alternative view.
  • Create a linkedResource that slurps up the image you want to embed.
  • Assign a content ID to the linked resource -- this should match the cid you used in the <img> tag.
  • Assign the image's file name to the linked resource.

Here is example code sample:

protected void btnSend_Click(object sender, EventArgs e)
    {
        MailMessage mail = BuildMail();
        SendEMail(mail);
    }

private MailMessage BuildMail()
    {
        string from, to, bcc, cc, subject, body;
        from = "uniquesaiful@gmail.com";   //Email Address of Sender
        to = "tips.asp.net@gmail.com,saifulondotnet@gmail.com,uniquesaiful@gmail.com";   //Email Address of Receiver
        bcc = "";
        cc = "";
        subject = "This is a test email. I am just checking whether email client is working properly.";
 
        string imagePath = Server.MapPath("~") + "\\";
        string fileName = imagePath + "Logo.JPG";
 
        StringBuilder sb = new StringBuilder();
        sb.Append("Hi Scott,<br/>");
        sb.Append("This is a test email. We are testing out email client. Please don't mind.<br/>");
        sb.Append("We are sorry for this unexpected mail to your mail box.<br/>");
        sb.Append("<br/>");
        sb.Append("Thanking you<br/>");
        sb.Append("Tips.Asp.Net");
 
        body = sb.ToString();
 
        AlternateView av = AlternateView.CreateAlternateViewFromString(body, nullMediaTypeNames.Text.Html);
        LinkedResource linkedRes = new LinkedResource(fileName);
        linkedRes.ContentId = "image1";
        linkedRes.ContentType.Name = fileName;
        av.LinkedResources.Add(linkedRes);
 
 
        MailMessage mail = new MailMessage();
        mail.From = new MailAddress(from);
        if (to.Contains(","))
        {
            string[] tos = to.Split(',');
            for (int i = 0; i < tos.Length; i++)
            {
                mail.To.Add(new MailAddress(tos[i]));
            }
        }
        else
        {
            mail.To.Add(new MailAddress(to));
        }
 
        if (!string.IsNullOrEmpty(bcc))
        {
            mail.Bcc.Add(new MailAddress(bcc));
        }
        if (!string.IsNullOrEmpty(cc))
        {
            mail.CC.Add(new MailAddress(cc));
        }
 
        mail.Subject = subject;
        mail.Body = body;
        mail.AlternateViews.Add(av);
        mail.IsBodyHtml = true;
 
        return mail;
    }
 
    private void SendEMail(MailMessage mail)
    {
        SmtpClient client = new SmtpClient();
        client.Host = "smtp.gmail.com";
        client.Port = 587;
        client.EnableSsl = true;
        client.Credentials = new System.Net.NetworkCredential("uniquesaiful"ami@janina.com);
        try
        {
            client.Send(mail);
        }
        catch (Exception ex)
        {
            throw ex;
        }
 
    }



Saturday, September 24, 2011

How can I send email easily in asp.net 1.1 version?

Problem: 
 I need to implement email sending functionality on one of my project but the project was developed on .Net framework 1.1 version and clients don't want to upgrade at this moment for some reasons. So is there any component that will allow me to develop that page easily.

Solution:
For those who are still working with ASP.NET 1.1, DotNetOpenMail (http://dotnetopenmail.sourceforge.net/) is a great library. It is a freely available open-source component written in C# that makes it easy to create HTML and plain text email with file attachments without needing the System.Web.Mail library. It allows inline graphics as well as SMTP authentication.

System.Net.Mail being redirected to other addresses

Problem: 
I have a small aspx site setup that uses System.Net.Mail on a few pages to send mail using Godaddy's relay-hosting.secureserver.net.  The site is hosted there as well.   The site will send me an email when someone logs in, visits certain pages, or when a client updates their information.  All of these emails are set to be From my address and To my address and it works fine.  What's happening however is about once a day, I'll get a mailer-daemon message saying that  the mail message  was not deliverable to about 15-20 addresses.  The content of the message is exactly like I would expect from my site, so it's not been changed for spamming.   I don't recognize any address nor are any of these addresses in the database the site uses nor are they anywhere in the directory of the site.

Solution:
 The answer is to use an alternative  for relay-hosting.secureserver.net.
The email server don't support that the email have too much email address.
You can try another email server to test it.

Thursday, September 15, 2011

ASP.NET MVC4 Developer Preview Released

 Microsoft has published ASP.NET MVC4 Developer Preview release. They have added a new page on ASP.NET MVC4 on www.asp.net site. The page link is: http://www.asp.net/mvc/mvc4 . You require Visual Studio 2010 or greater to install ASP.NET MVC4.

You can install it via Web Platform installer:

Some new features introduced in ASP.NET MVC 4 Developer Preview are listed here:
  • Enhancements to Default Project Templates: The new ASP.NET MVC4 project template has been updated to provide modern look and feel to your website.
  • Mobile Project Template: New Mobile Application Project template added to create mobile specific application.
  • Display Modes: This new feature enables you to select views depending on your browser.
  • jQuery Mobile, the View Switcher, and Browser Overriding:
  • Task Support for Asynchronous Controllers 

Saturday, September 10, 2011

How to Encrypt and Decrypt string?

Solution:
Following code examples show the way. It requires two references to include:

using System.Text;
using System.Security.Cryptography;

public static string Encrypt(string toEncrypt, bool useHashing)
        {

            byte[] keyArray;
            byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(toEncrypt);

            string key = "MySeCrEtKeY";

            if (useHashing)
            {
                MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
                keyArray = hashmd5.ComputeHash(UTF8Encoding.UTF8.GetBytes(key));
                hashmd5.Clear();
            }
            else
                keyArray = UTF8Encoding.UTF8.GetBytes(key);

            TripleDESCryptoServiceProvider tdes = new TripleDESCryptoServiceProvider();
            tdes.Key = keyArray;
            tdes.Mode = CipherMode.ECB;
            tdes.Padding = PaddingMode.PKCS7;

            ICryptoTransform cTransform = tdes.CreateEncryptor();
            byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
            tdes.Clear();
            return Convert.ToBase64String(resultArray, 0, resultArray.Length);
        }




public static string Decrypt(string cipherString, bool useHashing)
        {
            byte[] keyArray;
            byte[] toEncryptArray = Convert.FromBase64String(cipherString);

            string key = " MySeCrEtKeY";

            if (useHashing)
            {
                MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
                keyArray = hashmd5.ComputeHash(UTF8Encoding.UTF8.GetBytes(key));
                hashmd5.Clear();
            }
            else
                keyArray = UTF8Encoding.UTF8.GetBytes(key);

            TripleDESCryptoServiceProvider tdes = new TripleDESCryptoServiceProvider();
            tdes.Key = keyArray;
            tdes.Mode = CipherMode.ECB;
            tdes.Padding = PaddingMode.PKCS7;

            ICryptoTransform cTransform = tdes.CreateDecryptor();
            byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);

            tdes.Clear();
            return UTF8Encoding.UTF8.GetString(resultArray);
        }


Hope this will help.

Friday, September 9, 2011

How can I convert my VB.Net code to C# code and Vice Versa?


Solution:
 devloperFusion.com provides a free online tool that makes that conversion tasks very easy for developers. You can convert VB.Net code to C#, Python or Ruby code as well as C# code to VB.Net, Python or Ruby. This tool supports upto .net 3.5 syntax. To use the tool go to:
Convert VB.NET to C#
Convert C# to VB.NET


Thursday, September 8, 2011

How can I install asp.net membership schema in my existing database?

Installing membership related schema to an existing database is very easy task. Asp.net SQL Server Registration Tool(aspnet_regsql.exe) provides a very easy way to achieve the goal. We can run the registration tool from from Visual Studio Command Prompt or we can navigate to aspnet_regsql.exe file location and run the file.

To run from command prompt navigate to:
Start Menu> Microsoft Visual Studio 2010> Visual Studio Tools>Visual Studio Command Prompt(2010)
In the command prompt write aspnet_regsql command and press enter key as the screen shows.

To run from aspnet_regsql.exe  file location navigate to:
%Windows%\Microsoft.NET\Framework\v4.0.30319 and double click on aspnet_regsql.exe to run the tool.

ASP.NET SQL Server Setup Wizard will be appeared as follows:



Press Next button and you will get following screen:


On the next screen you will be prompted to select the database with credentials to which you want to setup membership.


Click Next to confirm your settings and click next again to execute the wizard and finally asp.net membership schema will be created on your database.

If you are interested to know more on asp.net membership you can navigate here:
Examining ASP.NET's Membership, Roles, and Profile

Thanks