Ever since Kernighan and Ritchie wrote a program to display "Hello World" in the C language, programming has never been the same. I have learnt and programmed a variety of new languages since then, and my first attempt at each new programming language has been to greet the world with a "Hello World". ASP .NET is not just a new revision of ASP. It is not ASP 4.0. It is a completely new paradigm and a new programming model and language. What better way to be introduced to this language than with a Hello World?
In this article, I will attempt to write a simple "Hello World" and explain all the code that goes behind this. ASP .NET generates a lot of code and files for you to support the notion of a Web Application, and we will dig into the details of an ASP .NET project.
A note about the attached code is due here. Due to the multiple files that VS .NET creates, the references to drives, and folders, it turned out to be very difficult for me to zip up all the code and link it to this document. It would have been next to impossible for someone to download this code and get it working "out of the box". As a result, I am only attaching the HelloWorld.aspx
and HelloWorld.vb
files and I would recommend you create an empty ASP .NET project and add these files to your project. A zipped version of the source code is available for download from here.
Creating an ASP .NET project is fairly simple. You will need to have the Beta 1 version of Microsoft Visual Studio .NET. In reality, you don't need this tool, it is possible to open up your favorite editor and start typing, but VS .NET provides a whole lot more than your simple Notepad. I will focus on creating ASP .NET projects using Microsoft VS .NET Beta 1. In order to create an ASP .NET project, follow these simple steps.
"New Project"
from VS .NET IDE. "Visual Basic Projects"
and chose the "Web Application Template"
. ASPHelloWorld
in this case) and voila! You have just created your first ASP .NET project. WebForm1.aspx
to a more meaningful name. In this sample, I have renamed it to HelloWorld.aspx
and this is how I will refer to it in this article. When you create an ASP .NET project, VS .NET by default creates the following main files for you. You should be able to view and open these files using the Solution Explorer. Let me start with a list of these files and a quick description of this. In the next section, I will deep deeper into each file and try to explain each in more detail.
In addition to these, VS .NET also creates the following files that are used internally by VS .NET. These contain details about the project settings etc. I would recommend you to open these in notepad and view them in order to understand how VS .NET uses these, but be careful not to modify these. Modifying these files could cause VS .NET to not recognize your project and not be able to open the solution.
Now that we have covered the basics, its time to dig into the real code.
Please enter your name |
This is what the HelloWorld
webform looks like. It asks you for your name and then proceeds to greet the world "Hello World" followed by your name in parenthesis.
Hello World (by Kaushal) |
Now that we know what the code does, lets dive into the code.
Lets start with digging into the details of the .aspx file that has been generated. Keep in mind, I have not written a single line of HTML for this. This is a very VB-sque experience. VS .NET provides a standard Toolbox that contains WebForm controls, HTML controls, Server controls etc, and building the UI is as simple as dragging and dropping these controls and setting their properties in the Properties window (again a feature inspired by the VB 6.0 Properties window). I will take certain sections of the generated code and discuss this. If you want to see how these sections fit together, or would like to look at the code in its entirety, I would suggest that you open the code (from the zip file) in VS .NET and follow along.
The first thing you will notice when you open up the HelloWorld.aspx
in an editor is this line:
|
This statement describes certain page level attributes for this aspx file. ASP .NET introduces a new syntactical construct <%@ ... %> which is used for specifying attributes. Every aspx file will have a statement similar to this that describes attributes such as the class that contains the event handler code, the name of the file containing the code, the language etc. This is necessary because ASP .NET cleanly distinguishes the presentation from the code. The aspx file only contains the HTML tags and server controls, while all the code needed to process the events that are fired by these controls are contained in a separate file. This allows the separation of effort between graphic designers who could be building beautiful pages and software engineers who could be writing beautiful code. The current ASP model mixes the HTML tags and controls with code, and anyone trying to read, maintain, or debug a 5000 line ASP file can attest to this.
There are too many ASP .NET attributes that can be covered here, so I will concentrate on some of the most important ones.
These controls form the heart of ASP .NET. These are rich server side controls that can be used to build a powerful UI on the web similar to Windows based user interfaces.
<asp:label id=lblName runat="server">Please enter your name</asp:label><asp:label id=lblHello runat="server"></asp:label><asp:textbox id=txtName runat="server"></asp:textbox><asp:button id=btnSubmit runat="server" Text="Submit"></asp:button> |
As you can see in the code above, the HelloWorld
example uses four ASP .Net controls. Note the "asp:"
prefix for each control. This is what distinguishes ASP .NET controls from standard HTML controls. We use two labels to display static messages, a textbox to allow the user to input the name, and a button that will be used as a submit button. These server side controls fire events very similar to the way windows controls fire events in a VB 6.0 program. These events can be trapped and code can be written to take action depending on what event is fired for what control. This offers much more functionality and flexibility that standard HTML controls. Currently ASP .NET supports the following types on server side controls:
This file contains the code that supports the ASP .NET controls from the HelloWorld.aspx file. This code is identical to VB code, in fact it is VB code. Lets start with some code excerpts, again I would recommend you to have VS .NET open and the project loaded and have the code in its entirety.
Imports SystemImports System.ComponentModel.DesignImports System.DataImports System.DrawingImports System.WebImports System.Web.SessionStateImports System.Web.UIImports System.Web.UI.WebControlsImports System.Web.UI.HtmlControlsImports Microsoft.VisualBasic |
.NET introduces the concept of namespaces. Namespaces are essentially a collection of types and functionality. VB .NET introduces the Imports
statement that is used to references assemblies outside your project. Most of the namespaces that are imported here are from the System
namespace, but you could import any namespace as long as it lives in a public assembly. Importing a namespace is similar to adding a reference to a DLL in VB 6.0. It allows you to access the public elements (classes, functions, methods, etc) in that namespace. In our example, VS .NET automatically imports these namespaces to add support for Web Controls. You could easily add to this default list. For example, if you wanted to add XML manipulation support to your code, you can add the "Imports System.XML"
line to your code.
Public Class HelloWorld Inherits System.Web.UI.Page Protected WithEvents lblName As System.Web.UI.WebControls.Label Protected WithEvents btnSubmit As System.Web.UI.WebControls.Button Protected WithEvents txtName As System.Web.UI.WebControls.TextBox Protected WithEvents lblHello As System.Web.UI.WebControls.Label Public Sub btnSubmit_Click(ByVal sender As Object, ByVal e As System.EventArgs) txtName.Visible = False lblName.Visible = False btnSubmit.Visible = False lblHello.Text = "Hello World (by " + txtName.Text + ")" lblHello.Visible = True End Sub Protected Sub WebForm1_Load(ByVal Sender As System.Object, ByVal e As System.EventArgs) ' Evals true first time browser hits the page If Not IsPostback Then lblHello.Visible = False End If End Sub End Class |
VB .NET is a purely object oriented language. (Of course, you could still write non-OO code and not use the OO features that VB .NET provides, but that defeats the purpose). Thus, all the code in the above figure resides in a class definition. We declare a public class named HelloWorld that forms the backbone of our HelloWorld.aspx page. All the code behind an ASP .NET page is derived from the System.Web.UI.Page
class, which contains the framework code for ASP .NET pages.
The four controls that are used on this page as defined as protected members of this class and the type of each controls is referenced from the System.Web.UI.WebControls
namespace. The WithEvents
keyword is used to specify that the object variables will respond to triggered events. In addition to these data members, you could add any data members that you may want to and specify the access modifiers (public, private, protected
) for these data members.
The crux of the logic in an ASP .NET page will live in the event handling code for one or more server side controls. In our trivial example, we handle two events. The first event is for the page load in which we simply hide the label that will be used to display the Hello World message. When the user clicks on the Submit
button, this will fire the event handled by the btnSubmit_Click
method. In this method, we simply read the value entered in the textbox and display the Hello World message. We also hide some of the controls that are no longer needed. This is all the code that is necessary to support our Hello World sample.
With ASP .NET, Microsoft introduces the notion of a human readable and modifiable configuration file for Web Applications. Those of you who have dealt with the IIS Metabase know that maintaining and modifying configuration wasn't exactly a breeze. ASP .NET introduces an XML file based configuration scheme, which is extremely powerful. The amount of details in the file warrants a whole new article, so I will focus only on some of the settings that are generated by VS .NET by default.
<compliation debugmode="true" /><customerrors mode="Off" /><trace enabled="false" requestlimit="0" pageoutput="false" tracemode="SortByTime"/><sessiostate inproc="true" usesqlserver="false" cookieless="false" timeout="20" server="localhost" port="42424"/> |
These are some of the default settings generated by VS .NET.
When I wrote my first Hello World in C, I used the following code
#include <stdio.h>int main (){ printf ("Hello World"); return 1;} |
My next Hello World was in C++, which took a few more lines, and then I moved over to Windows Programming in SDK, Windows Programming in MFC, COM Programming, COM Programming in ATL and slowly the complexity of the Hello World programs kept increasing. The same holds true for the Hello World that I wrote for ASP .NET. As you can see from the above code, the code needed to write a Hello World example takes far more than 7 lines. However, most of the code that is present is to support the framework and the plumbing needed to build complex real world applications. This is certainly true for ASP .NET, which is a huge huge improvement over traditional ASP, and Microsoft has brought VB-like development to the web. In future articles, I will dig deeper into the guts of ASP .NET.
Happy .Netting !
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=3471