Thursday, December 18, 2008

Generating Random Image on a button Click

Generating Random Image on a button Click


public static string GetRandomPassword(int length)
{
Random rand = new Random();
System.Text.StringBuilder password = new System.Text.StringBuilder(length);
for (int i = 1; i <= length; i++)
{
int charIndex;
do {
charIndex = rand.Next(48, 123);

}
while (!((charIndex >= 48 && charIndex <= 57) ||(charIndex >= 65 && charIndex <= 90)|| (charIndex >= 97 && charIndex <= 122)));
// add the random char to the password being built
password.Append(Convert.ToChar(charIndex));
}
return password.ToString();
}


private void GenerateImage(string strRegistrationStr)
{
System.Drawing.Bitmap objBitmap = new Bitmap(150, 30);
Graphics objGraphics = Graphics.FromImage(objBitmap);

//Fore Color and Background of Image
SolidBrush objForeColor = new SolidBrush(Color.White);
SolidBrush objBackColor = new SolidBrush(Color.Black);

objGraphics.FillRectangle(objBackColor, 0, 0, 150, 30);
//Font settings for Image
Font objFont = new Font("Arial", 15);
//Display from 5point from x-axis and 5point from y-axis
Point objPoint = new Point(5, 5);
//Drawing Registration String
objGraphics.DrawString(strRegistrationStr, objFont, objForeColor, objPoint);
//Saving Registration String as Image
//If you dont want image to save
//objBitmap.Save(Response.OutputStream, ImageFormat.Gif);
//otherwise use this
objBitmap.Save(Server.MapPath("RegistrationImg.gif"), ImageFormat.Gif);
//Release object
if (objBitmap != null)
objBitmap.Dispose();
if (objGraphics != null)
objGraphics.Dispose();
}

protected void butRegister_Click(object sender, EventArgs e)
{
GenerateImage(GetRandomPassword(10));
ImgRegistrationStr.ImageUrl = "RegistrationImg.gif";
}





Thanks,
Nitin Sharma

Tuesday, December 16, 2008

Fetching QueryString Parameters by Javascript

script language="javascript" type="text/javascript"
// Create a new QueryString object
//alert( window.top.location.search.substring(1));

var qrStr = window.location.search;
var spQrStr = qrStr.substring(1);
var arrQrStr = new Array();

// splits each of pair
var arr = spQrStr.split("&");

for (var i=0;i// splits each of field-value pair
var index = arr[i].indexOf("=");
var key = arr[i].substring(0,index);
var val = arr[i].substring(index+1);

// saves each of field-value pair in an array variable
arrQrStr[key] = val;
}


alert("Parameter:" + arrQrStr["company"]);

script


you just change the name of the paremeter in the alert('Parameter Name: '+ arrQrStr["company"]);

Here it is Company


Thanks,
Nitin Sharma

Monday, December 15, 2008

create,Read and erase Cookie in Javascript

The scripts
These are the three scripts you need
function createCookie(name,value,days) {
if (days) {
var date = new Date();
date.setTime(date.getTime()+(days*24*60*60*1000));
var expires = "; expires="+date.toGMTString();
}
else var expires = "";
document.cookie = name+"="+value+expires+"; path=/";
}


function readCookie(name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
while (c.charAt(0)==' ') c = c.substring(1,c.length);
if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
}
return null;
}


function eraseCookie(name) {
createCookie(name,"",-1);
}

Thanks,
Nitin Sharma

Thursday, December 4, 2008

Yield Keyword in C#

One interesting new feature of the C# 2।0 is the "yield" keyword. Basically it is used to iterate through objects returned by a method. It creates a state engine in IL so you can create methods that retain their state and dont have to go through the pain of maintaining state in your code.



public static IEnumerable GetInt()
{
for (int i = 0; i <>
yield return i;
}


Here's the implementation.


class प्रोग्राम
{ static void Main(string[] args)
{
foreach (int i in GetInt())
Console।WriteLine("Got " + i।ToString());
}


public static IEnumerable GetInt()
{
for (int i = 0; i <>
yield return i;
}
}

Thanks,
Nitin Sharma

Tuesday, December 2, 2008

Consuming Web Service by AJAX SlideShow Extender Control

Hi All,
     Here is a way to Consume Web Service in  AJAX SlideShowExtender Control using Context Key..

in .aspx page::

 if (Request.QueryString["Id"] != null)
        {
            uint Id = Convert.ToUInt16(Request.QueryString["Id"].ToString());
                       
          SlideShowExtender1.ContextKey = Id.ToString(); //Passing the ID attribute Dynamically
            
        }
 ------------------------------------------------------------------------------------
   div align="center"
    asp:Label runat="Server" ID="imageTitle" CssClass="slideTitle" 

    asp:Image ID="ImagePlayer" runat="server" Height="300" Style="border: 1px 
solid black; width: auto" 
    asp:Label runat="server" ID="imageDescription" CssClass="slideDescription"
    asp:Label
    
    asp:Button runat="Server" ID="btnBack" Text="Prev" Font-Size="Larger" 
    asp:Button runat="Server" ID="btnPlay" Text="Play" Font-Size="Larger" 
    asp:Button runat="Server" ID="btnNext" Text="Next" Font-Size="Larger" 
    cc1:SlideShowExtender ID="SlideShowExtender1" runat="server" TargetControlID="ImagePlayer"
        AutoPlay="True" Loop="True" NextButtonID="btnNext" PlayButtonID="btnPlay" PlayButtonText="Play"
        PreviousButtonID="btnBack" SlideShowServiceMethod="GetSlides" SlideShowServicePath="~/Test.asmx"
        StopButtonText="Pause" ImageDescriptionLabelID="imageDescription" ImageTitleLabelID="ImgTitle"
    cc1:SlideShowExtender>
    div

-------------------------------------------------------------------------------------

In .asmx(web service).cs page::
 [WebMethod]
    public AjaxControlToolkit.Slide[] GetSlides(string contextKey)
    {
        System.Web.UI.Page ObjUIPage = new System.Web.UI.Page();
        int i = 0;
        int j = 0;

        //'The below line specifies the Directory to be used.Here the images are in images folder of my application
        System.IO.DirectoryInfo DirInfo = new System.IO.DirectoryInfo(ObjUIPage.Server.MapPath("") + "\\PropertyUnitImages\\" + contextKey);
        System.IO.DirectoryInfo[] subDirs = DirInfo.GetDirectories();

        //'The below line gets the list of files in the directory specified above
        System.IO.FileInfo[] Files = DirInfo.GetFiles();

        //The below line gives the file count, which is useful to specify the size of array
        j = Files.Length;

        Slide[] mySlide = new AjaxControlToolkit.Slide[j + 1];
        //System.IO.FileInfo di = default(System.IO.FileInfo);

        //' This loop continues upto the last file in the directory
        foreach (var d in Files)
        {
            mySlide[i] = new AjaxControlToolkit.Slide(d.FullName, d.Name, d.Name.Substring(0, d.Name.IndexOf(".")));
            i = i + 1;
        }
        return mySlide;
        //' this line sends the dynamically added details as AjaxControlToolkit.Slide
    }
      





A word onContext Key  property of SlideShowExtender:



The parameter is contextKey of type String. You can use contextKey in anyway you want, it is meant to pass information from the calling AJAX control to the web service. In this application, the parameter will be used to supply the directory for the slide show to be fed from. The return parameter is an array of Slides. The AJAX SlideShow control looks for this signature and the signature is case sensitive and exact. Don't try to change any of this syntax or your service not be called.

Thanks,
Nitin Sharma

Friday, November 14, 2008

Some LINQ Queries

TestDataContext TDC = new TestDataContext();
    protected void Page_Load(object sender, EventArgs e)
    {
        var query = from table in TDC.PTables
                    where table.salary >= 10000
                    orderby table.Age descending
                    select new
                    {
                        Name = table.Name.ToUpper(),
                        Age = table.Age,
                       Country = table.Country

                    };

        gv1.DataSource = query;
        gv1.DataBind();
      



      //Showing a List of Process by LINQ
      var process = from p in System.Diagnostics.Process.GetProcesses()
                      orderby p.ProcessName
                    select new
                     {
                        p.ProcessName,
                          p.Id,
                         p.Threads,
                          p.HandleCount,
                          p.WorkingSet64
                          

                     };
      foreach (var test in process)
       {
           Response.Write(test+"
");
       }



      //Showing a List of Files by LINQ
        System.IO.DirectoryInfo DI  = new System.IO.DirectoryInfo("D:\\USBBackUP\\Cards\\Cards");

       var directoryList =
                from f in DI.GetFiles("*.*",
                System.IO.SearchOption.AllDirectories)
              select f;

      foreach( var row in directoryList)
       {
            Response.Write(row +"
");
       }
    }
   
    protected void btnInsert_Click(object sender, EventArgs e)
    {
        
        PTable ptable = new PTable();
        ptable.Age = "35";
        ptable.Name = "Nitin Sharma";
        ptable.Country = "INDIA";

        TDC.PTables.InsertOnSubmit(ptable);
        TDC.SubmitChanges();
        gv1.DataBind();

        
    }
    protected void btnDelete_Click(object sender, EventArgs e)
    {
       
        try
        {
            PTable todelete = TDC.PTables.Single(p => p.Name.Contains("Nitin"));
            TDC.PTables.DeleteOnSubmit(todelete);
            TDC.SubmitChanges();
        }
        catch (Exception ex)
        {
            Response.Write(ex.Message);
        }
        gv1.DataBind();
    }
    protected void btnUpdate_Click(object sender, EventArgs e)
    {
        var update = (from table in TDC.PTables
                     where table.CountryID == 8 
                     select table).Single();
        update.Name = txtName.Text;
        TDC.SubmitChanges();
        gv1.DataBind();
        txtName.Text = "";
       
       
        
    }

      

Thanks,
Nitin Sharma

Wednesday, November 5, 2008

Joins in LINQ


Using a Simple Join in LINQ:

 RekabuDataContext RKdb = new RekabuDataContext();

protected void Page_Load(object sender, EventArgs e)
    {
     
        BindGridView();
       
    }

public void BindGridView()
    {
        var q = from records in RKdb.Tests
                from recordsnew in RKdb.Images
                where records.id == recordsnew.id
                select recordsnew;
        gvRekabu.DataSource = q;
        gvRekabu.DataBind();
    }


Assigning Custom Columns header in LINQ:

public void Bind()
    {

        var q = from fields in RKdb.Tests
                where (fields.salary >= 20000)

                select new
                {
                    CandidateName = fields.Name,
                    CandidateLocation = fields.Loaction,
                    CandidateSalary = fields.salary,

                }
                ;

        gvRekabu.DataSource = q;
        gvRekabu.DataBind();
    
    }


Thanks,
Nitin Sharma

Tuesday, November 4, 2008

Tulsi Vivah on November 10,2008

Tulsi Vivah

The tulsi plant is held sacred by the Hindus as it is regarded as an incarnation of Mahalaxmi who was born as Vrinda. The festival of Tulsi Vivah is celebrated in each and every household of Goa. The one special feature of the festival is that of preparing various delicious sweet dishes at home. The women folk engage themselves in preparations well in advance. A typical Goan ojhe (load of sweets) is sent to the daughter from her parental home along with jodi (cotton threads used to light lamp while performing aarti). 

Tulsi was married to demon king Jalandhar. But she prayed to Lord Vishnu that her demon husband would be protected, with the result that no god was able to harm him. However on the request of the other gods, Lord Vishnu took the form of Jalandhar and stayed with the unsuspecting Tulsi. When the truth emerged after Jalandhar's death, Vrinda crused Vishnu and turned him to stone (Shaligram) and collapsed. From her body emerged the tulsi plant. That is why Vishnu pooja is considered incomplete without tulsi leaves. Tulsi vivah is celebrated on the next day of Kartiki Akadashi. On this day tulsi is married to Shaligram. 

On this day tulsivrindavan is coloured and decorated as a bride. Sugarcane and branches of tamarind and amla trees are planted along with the tulsi plant. Only vegetarian food is cooked on this day. At midday, a full meal consisting of rice, moongachi gathi, puri , sweet potato kheer , red pumpkin vegetable cooked with pieces of sugarcane, amla and tamarind is offered to Tulsi Vrindavan. Tulsi vivah ceremony takes place in the late evening. Various poha dishes are offered to Lord Vishnu. Then prasad is distributed among family members and friends.


Thanks,
Nitin Sharma

Tuesday, October 21, 2008

Dispose VS Finalize

1. Finalize() is the C# equivalent of destructor ~Object() syntax in C#. In VB.Net you implement the Finalize() by overriding it. But, in C# the compiler translates the destructor to a Finalize() method. 

2. Finalize() can NOT be overridden or called in C#. 

3. Since, Finalize() is called by the Garbage Collector, it is non-deterministic. 

4. Dispose() has to be implemented in classes implementing IDispose interface. 

5. Its the right place for freeing-up unmanaged resources like file, handles, and connections etc. 

6. Dispose() method is called explicitly in the code itself. 

7. Dispose() method is automatically called (for objects which implement IDispose), when used in a "using" statement.


Thanks,
Nitin Sharma

Gunas

The Gunas

According to the Sankhya philosophy, Prakriti is composed of three Gunas or forces, called Sattva (purity, light, harmony), Rajas (passion, activity, motion) and Tamas (inertia, darkness, inertness, inactivity).

 

Guna means a cord. The Gunas bind the soul with a triple bond. These Gunas are not the Nyaya-Vaiseshika Gunas. They are the actual substances or ingredients, of which Prakriti is constituted. They make up the whole world evolved out of Prakriti. They are not conjoined in equal quantities, but in varying proportions, one or the other being in excess. Just as Sat-Chit-Ananda is the Vedantic trinity, so also the Gunas are the Sankhyan trinity.

 

Interaction Between the Gunas Leads to Evolution

The three Gunas are never separate. They support one another. They intermingle with one another. They are intimately related as the flame, the oil and the wick of a lamp. They form the very substance of Prakriti. All objects are composed of the three Gunas. The Gunas act on one another. Then there is evolution or manifestation. Destruction is only non-manifestation.

 

The Gunas are the objects. Purusha is the witness-subject. Prakriti evolves under the influence of Purusha. Mahat or the Great (Intellect), the Cause of the whole world, is the first product of the evolution of Prakriti. Ahankara arises after Buddhi. Agency belongs to Ahankara. It is the principle that creates individuality. Mind is born of Ahankara. It carries out the orders of the will through the organs of action (Karma Indriyas). It reflects and doubts (Sankalpa-Vikalpa). It synthesises the sense-data into percepts. The mind takes part in both perception and action. There is no separate Prana Tattva in the Sankhya system. The Vedanta system has a separate Prana Tattva. In the Sankhya system, mind, with the organs, produces the five vital airs. Prana is a modification of the senses. It does not subsist in their absence.

 

Characteristics of the Three Gunas

Sattva is equilibrium. When Sattva prevails, there is peace or tranquillity. Rajas is activity which is expressed as Raga-Dvesha, likes or dislikes, love or hatred, attraction or repulsion. Tamas is that binding force with a tendency to lethargy, sloth and foolish actions. It causes delusion or non-discrimination.

 

When Sattva is predominant, it overpowers Rajas and Tamas. When Rajas is dominant, it overpowers Sattva and Tamas. When Tamas is predominant, it overpowers Rajas and Sattva.

 

How Man Is Affected by the Three Gunas

There are three Gunas in every man. Sometimes, Sattva prevails in him. Then he is calm and tranquil. He reflects and meditates. At other times, Rajas prevails in him and he does various sorts of worldly activities. He is passionate and active. Sometimes, Tamas prevails. He becomes lazy, dull, inactive and careless. Tamas generates delusion.

 

Again, one of these Gunas is generally predominant in different men. A Sattvic man is virtuous. He leads a pure and pious life. A Rajasic man is passionate and active. A Tamasic man is dull and inactive.

 

Sattva makes a man divine and noble, Rajas makes him thoroughly human and selfish, and Tamas makes him bestial and ignorant. There is much Sattva in a sage or saint and there is much Rajas in a soldier, politician and businessman.


Thanks,

Nitin Sharma

Friday, October 17, 2008

COALESCE function

COALESCE

Returns the first nonnull expression among its arguments.

Syntax

COALESCE expression [ ,...n )

Arguments

expression

Is an expression of any type.

n

Is a placeholder indicating that multiple expressions can be specified. All expressions must be of the same type or must be implicitly convertible to the same type.

Return Types

Returns the same value as expression.

Remarks

If all arguments are NULL, COALESCE returns NULL.

COALESCE(expression1,...n) is equivalent to this CASE function:

CASE    WHEN (expression1 IS NOT NULL) THEN expression1    ...    WHEN (expressionN IS NOT NULL) THEN expressionN    ELSE NULL 
Examples

In this example, the wages table is shown to include three columns with information about an employee's yearly wage: hourly_wagesalary, and commission. However, an employee receives only one type of pay. To determine the total amount paid to all employees, use the COALESCE function to receive only the nonnull value found inhourly_wagesalary, and commission.

SET NOCOUNT ON GO USE master IF EXISTS 
(SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES        WHERE TABLE_NAME = 'wages')
   DROP TABLE wages
GO
CREATE TABLE wages (    emp_id      tinyint    identity,    hourly_wage   decimal   NULL,    salary      decimal    NULL,    commission   decimal   NULL,    num_sales   tinyint   NULL ) GO
INSERT wages VALUES(10.00, NULL, NULL, NULL)
INSERT wages VALUES(20.00, NULL, NULL, NULL)
INSERT wages VALUES(30.00, NULL, NULL, NULL)
INSERT wages VALUES(40.00, NULL, NULL, NULL)
INSERT wages VALUES(NULL, 10000.00, NULL, NULL)
INSERT wages VALUES(NULL, 20000.00, NULL, NULL)
INSERT wages VALUES(NULL, 30000.00, NULL, NULL)
INSERT wages VALUES(NULL, 40000.00, NULL, NULL)
INSERT wages VALUES(NULL, NULL, 15000, 3)
INSERT wages VALUES(NULL, NULL, 25000, 2)
INSERT wages VALUES(NULL, NULL, 20000, 6)
INSERT wages VALUES(NULL, NULL, 14000, 4)
GO SET NOCOUNT OFF GO SELECT CAST(COALESCE(hourly_wage * 40 * 52,     salary,     commission * num_sales) AS money) AS 'Total Salary'  FROM wages GO 

Here is the result set:

Total Salary  ------------  20800.0000
41600.0000
62400.0000
83200.0000
10000.0000 
20000.0000
30000.0000
40000.0000
45000.0000
50000.0000
120000.0000
56000.0000
(12 row(s) affected)

Thanks,
Nitin Sharma

Thursday, October 16, 2008

ASP.NET Tips and Practices to improve Performance

Introduction 
Performance tuning can be tricky. It's especially tough in Internet-related projects with lots of components running around, like HTML client, HTTP network, Web server, middle-tier components, database components, resource-management components, TCP/IP networks, and database servers. Performance tuning depends on a lot of parameters and sometimes, by changing a single parameter, performance can increase drastically.



Tips For Web Application


1) Turn off Tracing unless until required 
Tracing is one of the wonderful features which enable us to track the application's trace and the sequences. However, again it is useful only for developers and you can set this to "false" unless you require to monitor the trace logging. 
How it affects performance: 
Enabling tracing adds performance overhead and might expose private information, so it should be enabled only while an application is being actively analyzed. 
Solution: 
When not needed, tracing can be turned off using 
 


2) Turn off Session State, if not required 
One extremely powerful feature of ASP.NET is its ability to store session state for users, such as a shopping cart on an e-commerce site or a browser history. 
How it affects performance: 
Since ASP.NET Manages session state by default, you pay the cost in memory even if you don't use it. I.e. whether you store your data in in-process or on state server or in a Sql Database, session state requires memory and it's also time consuming when you store or retrieve data from it. 
Solution: 
You may not require session state when your pages are static or when you do not need to store information captured in the page. 
In such cases where you need not use session state, disable it on your web form using the directive, 
<@%Page EnableSessionState="false"%> 
In case you use the session state only to retrieve data from it and not to update it, make the session state read only by using the directive, 
<@%Page EnableSessionState ="ReadOnly"%> 

3) Disable View State of a Page if possible 
View state is a fancy name for ASP.NET storing some state data in a hidden input field inside the generated page. When the page is posted back to the server, the server can parse, validate, and apply this view state data back to the page's tree of controls. 
View state is a very powerful capability since it allows state to be persisted with the client and it requires no cookies or server memory to save this state. Many ASP.NET server controls use view state to persist settings made during interactions with elements on the page, for example, saving the current page that is being displayed when paging through data. 
How it affects performance: 
 There are a number of drawbacks to the use of view state, however. 
 It increases the total payload of the page both when served and when requested. There is also an additional overhead incurred when serializing or deserializing view state data that is posted back to the server. 
 View state increases the memory allocations on the server. Several server controls, the most well known of which is the DataGrid, tend to make excessive use of view state, even in cases where it is not needed. 
Solution: 
Pages that do not have any server postback events can have the view state turned off. 
The default behavior of the ViewState property is enabled, but if you don't need it, you can turn it off at the control or page level. Within a control, simply set the EnableViewState property to false, or set it globally within the page using this setting: 
 
If you turn view state off for a page or control, make sure you thoroughly test your pages to verify that they continue to function correctly. 






4) Set debug=false in web.config 
When you create the application, by default this attribute is set to "true" which is very useful while developing. However, when you are deploying your application, always set it to "false". 
How it affects performance: 
Setting it to "true" requires the pdb information to be inserted into the file and this results in a comparatively larger file and hence processing will be slow. 
Solution: 
Therefore, always set 
debug="false" before deployment. 

5) Avoid Response.Redirect 
Response.Redirect () method simply tells the browser to visit another page. 
How it affects performance: 
Redirects are also very chatty. They should only be used when you are transferring people to another physical web server. 
Solution: 
For any transfers within your server, use .transfer! You will save a lot of needless HTTP requests. Instead of telling the browser to redirect, it simply changes the "focus" on the Web server and transfers the request. This means you don't get quite as many HTTP requests coming through, which therefore eases the pressure on your Web server and makes your applications run faster. 

Tradeoffs: 
 ".transfer" process can work on only those sites running on the server. Only 
Response.Redirect can do that. 
 Server.Transfer maintains the original URL in the browser. This can really help streamline data entry techniques, although it may make for confusion when debugging 
5. A) To reduce CLR Exceptions count, Use Response.Redirect (".aspx", false) instead of 
response.redirect (".aspx"). 

6) Use the String builder to concatenate string 
How it affects performance: 
String is Evil when you want to append and concatenate text to your string. All the activities you do to the string are stored in the memory as separate references and it must be avoided as much as possible. 
i.e. When a string is modified, the run time will create a new string and return it, leaving the original to be garbage collected. Most of the time this is a fast and simple way to do it, but when a string is being modified repeatedly it begins to be a burden on performance: all of those allocations eventually get expensive. 
Solution: 
Use String Builder when ever string concatenation is needed so that it only stores the value in the original string and no additional reference is created. 


7) Avoid throwing exceptions 
How it affects performance: 
Exceptions are probably one of the heaviest resource hogs and causes of slowdowns you will ever see in web applications, as well as windows applications. 
Solution: 
You can use as many try/catch blocks as you want. Using exceptions gratuitously is where you lose performance. For example, you should stay away from things like using exceptions for control flow. 

8) Use Finally Method to kill resources 
The finally method gets executed independent of the outcome of the Block. 
Always use the finally block to kill resources like closing database connection, closing files and other resources such that they get executed independent of whether the code worked in Try or went to Catch. 

9) Use Client Side Scripts for validations 
User Input is Evil and it must be thoroughly validated before processing to avoid overhead and possible injections to your applications. 
How It improves performance: 
Client site validation can help reduce round trips that are required to process user's request. In ASP.NET you can also use client side controls to validate user input. However, do a check at the Server side too to avoid the infamous Javascript disabled scenarios. 

10) Avoid unnecessary round trips to the server 
How it affects performance: 
Round trips significantly affect performance. They are subject to network latency and to downstream server latency. Many data-driven Web sites heavily access the database for every user request. While connection pooling helps, the increased network traffic and processing load on the database server can adversely affect performance. 
Solution: 
 Keep round trips to an absolute minimum 
 Implement Ajax UI whenever possible. The idea is to avoid full page refresh and only update the portion of the page that needs to be changed 

11) Use Page.ISPostBack 
Make sure you don't execute code needlessly. Use Page.ISPostBack property to ensure that you only perform page initialization logic when a page is first time loaded and not in response to client postbacks. 

12) Include Return Statements with in the Function/Method 
How it improves performance 
Explicitly using return allows the JIT to perform slightly more optimizations. Without a return statement, each function/method is given several local variables on stack to transparently support returning values without the keyword. Keeping these around makes it harder for the JIT to optimize, and can impact the performance of your code. Look through your functions/methods and insert return as needed. It doesn't change the semantics of the code at all, and it can help you get more speed from your application. 

13) Use Foreach loop instead of For loop for String Iteration 
Foreach is far more readable, and in the future it will become as fast as a For loop for special cases like strings. Unless string manipulation is a real performance hog for you, the slightly messier code may not be worth it. 

14) Avoid Unnecessary Indirection 
How it affects performance: 
When you use byRef, you pass pointers instead of the actual object. 
Many times this makes sense (side-effecting functions, for example), but you don't always need it. Passing pointers results in more indirection, which is slower than accessing a value that is on the stack. 
Solution: 
When you don't need to go through the heap, it is best to avoid it there by avoiding indirection. 

15) Use "ArrayLists" in place of arrays 
How it improves performance 
An ArrayList as everything that is good about an array PLUS automatic sizing, Add, Insert, Remove, Sort, Binary Search. All these great helper methods are added when implementing the IList interface. 
Tradeoffs: 
The downside of an ArrayList is the need to cast objects upon retrieval. 

16) Always check Page.IsValid when using Validator Controls 
Always make sure you check Page.IsValid before processing your forms when using Validator Controls. 

17) Use Paging 
Take advantage of paging's simplicity in .net. Only show small subsets of data at a time, allowing the page to load faster. 
Tradeoffs: 
Just be careful when you mix in caching. Don't cache all the data in the grid. 

18) Store your content by using caching 
How it improves performance: 
ASP.NET allows you to cache entire pages, fragment of pages or controls. You can cache also variable data by specifying the parameters that the data depends. By using caching you help ASP.NET engine to return data for repeated request for the same page much faster. 
When and Why Use Caching: 
A Proper use and fine tune of caching approach of caching will result on better performance and scalability of your site. However improper use of caching will actually slow down and consume lots of your server performance and memory usage. 
Good candidate to use caching is if you have infrequent chance of data or static content of web page. 

19) Use low cost authentication 
Authentication can also have an impact over the performance of your application. For example passport authentication is slower than form-base authentication which in here turn is slower than Windows authentication. 

20) Minimize the number of web server controls 
How it affects performance: 
The use of web server controls increases the response time of your application because they need time to be processed on the server side before they are rendered on the client side. 
Solution: 
One way to minimize the number of web server controls is to taking into consideration, the usage of HTML elements where they are suited, for example if you want to display static text. 

21) Avoid using unmanaged code 
How it affects performance: 
Calls to unmanaged code are a costly marshaling operation. 
Solution: 
Try to reduce the number calls between the managed and unmanaged code. Consider to do more work in each call rather than making frequent calls to do small tasks. 

22) Avoid making frequent calls across processes 
If you are working with distributed applications, this involves additional overhead negotiating network and application level protocols. In this case network speed can also be a bottleneck. Try to do as much work as possible in fewer calls over the network. 

23) Cleaning Up Style Sheets and Script Files 
 A quick and easy way to improve your web application's performance is by going back and cleaning up your CSS Style Sheets and Script Files of unnecessary code or old styles and functions. It is common for old styles and functions to still exist in your style sheets and script files during development cycles and when improvements are made to a website. 
 Many websites use a single CSS Style Sheet or Script File for the entire website. Sometimes, just going through these files and cleaning them up can improve the performance of your site by reducing the page size. If you are referencing images in your style sheet that are no longer used on your website, it's a waste of performance to leave them in there and have them loaded each time the style sheet is loaded. 
 Run a web page analyzer against pages in your website so that you can see exactly what is being loaded and what takes the most time to load. 

24) Design with ValueTypes 
Use simple structs when you can, and when you don't do a lot of boxing 
and unboxing. 
Tradeoffs: 
ValueTypes are far less flexible than Objects, and end up hurting performance if used incorrectly. You need to be very careful about when you treat them like objects. This adds extra boxing and unboxing overhead to your program, and can end up costing you more than it would if you had stuck with objects. 

25) Minimize assemblies 
Minimize the number of assemblies you use to keep your working set small. If you load an entire assembly just to use one method, you're paying a tremendous cost for very little benefit. See if you can duplicate that method's functionality using code that you already have loaded. 

26) Encode Using ASCII When You Don't Need UTF 
By default, ASP.NET comes configured to encode requests and responses as UTF-8. 
If ASCII is all your application needs, eliminated the UTF overhead can give you back a few cycles. Note that this can only be done on a per-application basis. 

27) Avoid Recursive Functions / Nested Loops 
These are general things to adopt in any programming language, which consume lot of memory. Always avoid Nested Loops, Recursive functions, to improve performance. 

28) Minimize the Use of Format () 
When you can, use toString () instead of format (). In most cases, it will provide you with the functionality you need, with much less overhead. 

29) Place StyleSheets into the Header 
Web developers who care about performance want browser to load whatever content it has as soon as possible. This fact is especially important for pages with a lot of content and for users with slow Internet connections. When the browser loads the page progressively the header, the logo, the navigation components serve as visual feedback for the user. 
When we place style sheets near the bottom part of the html, most browsers stop rendering to avoid redrawing elements of the page if their styles change thus decreasing the performance of the page. So, always place StyleSheets into the Header 

30) Put Scripts to the end of Document 
Unlike StyleSheets, it is better to place scripts to the end of the document. Progressive rendering is blocked until all StyleSheets have been downloaded. Scripts cause progressive rendering to stop for all content below the script until it is fully loaded. Moreover, while downloading a script, browser does not start any other component downloads, even on different hostnames. 
So,always have scripts at the end of the document. 

31) Make JavaScript and CSS External 
Using external files generally produces faster pages because the JavaScript and CSS files are cached by the browser. Inline JavaScript and CSS increases the HTML document size but reduces the number of HTTP requests. With cached external files, the size of the HTML is kept small without increasing the number of HTTP requests thus improving the performance. 


Tips For Database Operations


1) Return Multiple Resultsets 
The database code if has request paths that go to the database more than once then, these round-trips decreases the number of requests per second your application can serve. 
Solution: 
Return multiple resultsets in a single database request, so that you can cut the total time spent communicating with the database. You'll be making your system more scalable, too, as you'll cut down on the work the database server is doing managing requests. 

2) Connection Pooling and Object Pooling 
Connection pooling is a useful way to reuse connections for multiple requests, rather than paying the overhead of opening and closing a connection for each request. It's done implicitly, but you get one pool per unique connection string. Make sure you call Close or Dispose on a connection as soon as possible. When pooling is enabled, calling Close or Dispose returns the connection to the pool instead of closing the underlying database connection. 
Account for the following issues when pooling is a part of your design: 
 Share connections 
 Avoid per-user logons to the database 
 Do not vary connection strings 
 Do not cache connections 

3) Use SqlDataReader Instead of Dataset wherever it is possible 
If you are reading a table sequentially you should use the DataReader rather than DataSet. DataReader object creates a read only stream of data that will increase your application performance because only one row is in memory at a time. 

4) Keep Your Datasets Lean 
Remember that the dataset stores all of its data in memory, and that the more data you request, the longer it will take to transmit across the wire. 
Therefore Only put the records you need into the dataset. 

5) Avoid Inefficient queries 
How it affects performance: 
Queries that process and then return more columns or rows than necessary, waste processing cycles that could best be used for servicing other requests. 

Cause of Inefficient queries: 
 Too much data in your results is usually the result of inefficient queries. 
 The SELECT * query often causes this problem. You do not usually need to return all the columns in a row. Also, analyze the WHERE clause in your queries to ensure that you are not returning too many rows. Try to make the WHERE clause as specific as possible to ensure that the least number of rows are returned. 
 Queries that do not take advantage of indexes may also cause poor performance. 

6) Unnecessary round trips 
How it affects performance: 
Round trips significantly affect performance. They are subject to network latency and to downstream server latency. Many data-driven Web sites heavily access the database for every user request. While connection pooling helps, the increased network traffic and processing load on the database server can adversely affect performance. 
Solution: 
Keep round trips to an absolute minimum. 

7) Too many open connections 
Connections are an expensive and scarce resource, which should be shared between callers by using connection pooling. Opening a connection for each caller limits scalability. 
Solution: 
To ensure the efficient use of connection pooling, avoid keeping connections open and avoid varying connection strings. 

8) Avoid Transaction misuse 
How it affects performance: 
If you select the wrong type of transaction management, you may add latency to each operation. Additionally, if you keep transactions active for long periods of time, the active transactions may cause resource pressure. 
Solution: 
Transactions are necessary to ensure the integrity of your data, but you need to ensure that you use the appropriate type of transaction for the shortest duration possible and only where necessary. 

9) Avoid Over Normalized tables 
Over Normalized tables may require excessive joins for simple operations. These additional steps may significantly affect the performance and scalability of your application, especially as the number of users and requests increases. 

10) Reduce Serialization 
Dataset serialization is more efficiently implemented in .NET Framework version 1.1 than in version 1.0. However, Dataset serialization often introduces performance bottlenecks. 
You can reduce the performance impact in a number of ways: 
 Use column name aliasing 
 Avoid serializing multiple versions of the same data 
 Reduce the number of DataTable objects that are serialized 

11) Do Not Use CommandBuilder at Run Time 
How it affects performance: 
CommandBuilder objects such as as SqlCommandBuilder and OleDbCommandBuilder are useful when you are designing and prototyping your application. However, you should not use them in production applications. The processing required to generate the commands affects performance. 
Solution: 
Manually create stored procedures for your commands, or use the Visual Studio® .NET design-time wizard and customize them later if necessary. 

12) Use Stored Procedures Whenever Possible 
Stored procedures are highly optimized tools that result in excellent performance when used effectively. 
Set up stored procedures to handle inserts, updates, and deletes with the data adapter 
Stored procedures do not have to be interpreted, compiled or even transmitted from the client, and cut down on both network traffic and server overhead. 
Be sure to use CommandType.StoredProcedure instead of CommandType.Text 

13) Avoid Auto-Generated Commands 
When using a data adapter, avoid auto-generated commands. These require additional trips to the server to retrieve meta data, and give you a lower level of interaction control. While using auto-generated commands is convenient, it's worth the effort to do it yourself in performance-critical applications. 

14) Use Sequential Access as Often as Possible 
With a data reader, use CommandBehavior.SequentialAccess. This is essential for dealing with blob data types since it allows data to be read off of the wire in small chunks. While you can only work with one piece of the data at a time, the latency for loading a large data type disappears. If you don't need to work the whole object at once, using 
Sequential Access will give you much better performance. 


Tips for Asp.Net applications developed using VB


1) Enable Option Strict and Option Explicit for your pages 
With Option Strict on, you protect yourself from inadvertent late binding and enforce a higher level of coding discipline.

2) Use early binding in Visual Basic or JScript code 
Visual Basic 6 does a lot of work under the hood to support casting of objects, and many programmers aren't even aware of it. In Visual Basic 7, this is an area that out of which you can squeeze a lot of performance. 
Solution: 
When you compile, use early binding. This tells the compiler to insert a Type Coercion is only done when explicitly mentioned. 
This has two major effects: 
 Strange errors become easier to track down. 
 Unneeded coercions are eliminated, leading to substantial performance improvements. 
When you use an object as if it were of a different type, Visual Basic will coerce the object for you if you don't specify. This is handy, since the programmer has to worry about less code. 

3) Put Concatenations in One Expression 
If you have multiple concatenations on multiple lines, try to stick them all on one expression. The compiler can optimize by modifying the string in place, providing a speed and memory boost. If the statements are split into multiple lines, the Visual Basic compiler will not generate the Microsoft Intermediate Language (MSIL) to allow in-place concatenation. 


Thanks,
Nitin Sharma

The deployment retail=”true” Switch in Maching.config

If you are a server administrator and want to ensure that no one accidentally deploys an ASP.NET application in production with the switch enabled within the application’s web.config file, one trick you can use with ASP.NET V2.0 is to take advantage of the section within your machine.config file.

 

Specifically, by setting this within your machine.config file:

 

configuration

    system.web

          deployment retail=”true”

    system.web

configuration


Thanks,

Nitin Sharma

Tuesday, October 14, 2008

Error Retrieving from Windows in asp.net

To retrieve error message or warning message from Windows event log in ASP.NET 2.0 and C# is very simple.


At first, import the namespace of System.Diagnostics

using System.Diagnostics;

Create Eventlog object

EventLog objEventLog = new EventLog("System");



Use looping to retrieve all error message from event log

If you want get the information or warning messages from event log, just use EventLogEntryType.Information or EventLogEntryType.Warning to replace EventLogEntryType.Error

foreach (EventLogEntry objEntry in objEventLog.Entries)
{
if(objEntry.EntryType==EventLogEntryType.Error)
{
Response.Write(objEntry.TimeGenerated+"-"+objEntry.Source+"- "+objEntry.Message+"
");
}
}

The flow for the code behind page is as follows.

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Text;
using System.Diagnostics;

public partial class _Default : System.Web.UI.Page 
{
protected void Page_Load(object sender, EventArgs e)
{
EventLog objEventLog = new EventLog("System");

foreach (EventLogEntry objEntry in objEventLog.Entries)
{
if(objEntry.EntryType==EventLogEntryType.Error)
{
Response.Write(objEntry.TimeGenerated+"-"+objEntry.Source+"- "+objEntry.Message+"
");
}
}
}
}

DataTable and XML

Creating a DataTable

To create a DataTable, you need to use System.Data namespace, generally when you create a new class or page, it is included by default by the Visual Studio. Lets write following code to create a DataTable object. Here, I have pased a string as the DataTable name while creating DataTable object.

// instantiate DataTable

DataTable dTable = new DataTable("Dynamically_Generated");

Creating Columns in the DataTable

To create column in the DataTable, you need to use DataColumn object. Instantiate the DataColumn object and pass column name and its data type as parameter. Then call add method of DataTable column and pass the DataColumn object as parameter.

// create columns for the DataTable

DataColumn auto = new DataColumn("AutoID", typeof(System.Int32));

dTable.Columns.Add(auto);

// create another column

DataColumn name = new DataColumn("Name", typeof(string));

dTable.Columns.Add(name);

// create one more column

DataColumn address = new DataColumn("Address", typeof(string));

dTable.Columns.Add(address);

Specifying AutoIncrement column in the DataTable

To specify a column as AutoIncrement (naturally it should be an integer type of field only), you need to set some properties of the column like AutoIncrement, AutoIncrementSeed. 

// specify it as auto increment field

auto.AutoIncrement = true;

auto.AutoIncrementSeed = 1;

auto.ReadOnly = true;

If you want a particular column to be a unique column ie. you don't want duplicate records into that column, then set its Unique property to true like below.

auto.Unique = true;

Specifying Primary Key column in the DataTable

To set the primary key column in the DataTable, you need to create arrays of column and store column you want as primary key for the DataTable and set its PrimaryKey property to the column arrays. See the code below.

// create primary key on this field

DataColumn[] pK = new DataColumn[1];

pK[0] = auto;

dTable.PrimaryKey = pK;


Populating data into DataTable

There are two ways to populate DataTable.

Using DataRow object

// populate the DataTable using DataRow object

DataRow row = null;

for (int i = 0; i <>

{

row = dTable.NewRow();

row["AutoID"] = i + 1;

row["Name"] = i + " - Ram";

row["Address"] = "Ram Nagar, India - " + i;

dTable.Rows.Add(row);

}


Asiging the value of column using Arrays

// manually adding rows using array of values

dTable.Rows.Add(6, "Manual Data - 1", "Manual Address - 1, USA");

dTable.Rows.Add(7, "Manual Data - 2", "Manual Address - 2, USA");

Modifying data into DataTable

Modifying Row Data

// modify certain values into the DataTable

dTable.Rows[2]["AutoID"] = 20;

dTable.Rows[2]["Name"] = "Modified";

dTable.Rows[2]["Address"] = "Modified Address";

dTable.AcceptChanges();

Deleting Row


// Delete row

dTable.Rows[1].Delete();

dTable.AcceptChanges();

 

Filtering data from DataTable

To filter records from the DataTable, use Select method and pass necessary filter expression. In below code, the 1st line will simply filter all rows whose AutoID value is greater than 5. The 2nd line of the code filters the DataTable whose AutoID value is greater than 5 after sorting it.

DataRow[] rows = dTable.Select(" AutoID > 5");

DataRow[] rows1 = dTable.Select(" AutoID > 5", "AuotID ASC");

Note that Select method of the DataTable returns the array of rows that matche the filter expression. If you want to loop through all the filtered rows, you can use foreach loop as shown below. In this code, I am adding all the filtered rows into another DataTable.

foreach (DataRow thisRow in rows)

{

// add values into the datatable

dTable1.Rows.Add(thisRow.ItemArray);

}

Sorting data of DataTable
Using DataView

See the code below. 

// Sorting DataTable

DataView dataView = new DataView(dTable);

dataView.Sort = " AutoID DESC, Name DESC";

foreach (DataRowView view in dataView)

{

Response.Write(view["Address"].ToString());

}

Using DataTable.Select() method

Yes, you can sort all the rows using Select method too provided you have not specified any filter expression. If you will specify the filter expression, ofcourse your rows will be sorted but filter will also be applied. A small drawback of this way of sorting is that it will return array of DataRows as descibed earlier so if you are planning to bind it to the Data controls like GridView or DataList you will have for form a DataTable by looping through because directly binding arrays of rows to the Data controls will not give desired results.

DataRow[] rows = dTable.Select("", "AutoID DESC");

Writing and Reading XmlSchema of the DataTable

If you need XmlSchema of the DataTabe, you can use WriteXmlSchema to write and ReadXmlSchema to read it. There are several overloads methods of both methods and you can pass filename, stream, TextReader, XmlReader etc. as the parameter. In this code, the schema will be written to the .xml file and will be read from there.

// creating schema definition of the DataTable

dTable.WriteXmlSchema(Server.MapPath("~/DataTableSchema.xml"));

// Reading XmlSchema from the xml file we just created

DataTable dTableXmlSchema = new DataTable();

dTableXmlSchema.ReadXmlSchema(Server.MapPath("~/DataTableSchema.xml"));

Reading/Writing from/to Xml

If you have a scenario, where you need to write the data of the DataTable into xml format, you can use WriteXml method of the DataTable. Note that WriteXml method will not work if you will not specify the name of the DataTable object while creating it. Look at the first code block above.

// Note: In order to write the DataTable into XML,

// you must define the name of the DataTable while creating it

// Also if you are planning to read back this XML into DataTable, you should define the XmlWriteMode.WriteSchema too

// Otherwise ReadXml method will not understand simple xml file

dTable.WriteXml(Server.MapPath("~/DataTable.xml"), XmlWriteMode.WriteSchema);

// Loading Data from XML into DataTable

DataTable dTableXml = new DataTable();

dTableXml.ReadXml(Server.MapPath("~/DataTable.xml"));

If you are planning to read the xml you have just created into the DataTable sometime later then you need to specify XmlWriteMode.WriteSchema too as the 2nd parameter while calling WriteXml method of the DataTable otherwise normally WriteXml method doesn't write schema of the DataTable. In the abscence of the schema, you will get error (DataTable does not support schema inference from Xml) while calling ReadXml method of the DataTable.

 


Source:http://www.dotnetfunda.com/articles/article131.aspx 


Thanks,
Nitin Sharma