New
New
New
ASP.NET is a Server-Side technology which uses object-oriented programming approach. Every element
in ASP.NET is treated as an object and run on the server.
ASP.NET allows you to use a fully featured programming language like C-Sharp (C#) or VB.NET to build
web applications easily.
The basic difference between ASP and ASP.NET is that, ASP.NET is compiled whereas ASP is interpreted
whereas. This implies that since ASP mainly uses VBScript, when an ASP page is executed, it is
interpreted. On the other hand, ASP.NET uses .NET languages, such as C# and VB.NET, which are
compiled to Microsoft Intermediate Language (MSIL).
Scripting is separated from the HTML, Code is compiled as a DLL, these DLLs can be executed on the
server.
There will be a roundtrip of the page between client and a server in request-response model, so this
mechanism is called Post Back.
In server side code we have a property called "IsPostBack” which is used to identify whether page is
posted back or not. We can set the “AutoPostBack” at the control level where page is posted back when
the state of control is changed.
Response.Redirect sends message to the browser saying it to move to some different page, but
Server.Transfer does not send any message to the browser but rather redirects the user directly from
the server itself. So in ServerTransfer there is no round trip while Response.Redirect has a round trip and
will puts more load on server.
Server.Transfer() method is used for posting the data from one page to another.
In cross page posting, data collected from different pages and will be displayed in single page. So, for
doing this we need to set “PostBackUrl” property of the control, in which target page is specified and in
target page we can use “PreviousPage” property. For doing this we need to set the directive -
@PreviousPageType. Previous page control can be accessed from the method – “FindControl()”.
ASP.NET offers many server controls like Textbox, Button Dropdown List etc. Each control will respond
to the user’s actions using events and event handler mechanism. Following are the Server Control
Events:
Postback events - These events sends the web page to the server for processing. Once processing is
finished, web page will send data back to the same page on the server.
Cached events - These events are processed when a postback event occurs.
Link buttons will have events which can be handled in code behind file.
Hyperlink control will not be having events like click and command events.
Following are the steps which will occur when we request an ASPX page from web server –
The browser sends the request to the webserver. Let’s assume the webserver at the other end is IIS.
Once IIS receives the request, it looks for engine where it can serve this request. When engine means it’s
the DLL which can parse this page or compile and send a response back to browser. The request which is
to be mapped is decided by file extension of the page requested.
Some File extension mapping given below -
.aspx, for ASP.NET Web pages,
.asmx, for ASP.NET Web services,
.config, for ASP.NET configuration files,
.ashx, for custom ASP.NET HTTP handlers,
.rem, for remoting resources
HTML elements are treated as text by default. Once we add “runat=server” attribute to HTML element,
it will be treated as a server control. If we add “runat=server” attribute we have to make sure this
element is in <form> tag because it indicates that form is processed by server.
By adding ValidationSummary control to web page we can display all the validation messages related to
different validation controls
Below is a code snippet for custom validator, which is checking whether a textbox have a zero value –
<asp:CustomValidator id="MyTestCustomValidator"
runat="server"
ErrorMessage="Divided by Zero Error"
ControlToValidate=" txtTestMyNumber"
OnServerValidate="ServerValidate"
ClientValidationFunction="CheckZero" />
<asp:TextBox id="txtTestMyNumber" runat="server" />
<script language="javascript">
function CheckZero(source, args)
{
int val = parseInt(args.Value, 8);
if (val ==0)
{
args.IsValid = false;
}
}
</script>
As shown above “txtNumber” is the text box name where in value will be entered and client script
“CheckZero” checking for zero value.
How many validations can be applied on customer’s “Age” field?
Two validations can be applied for this field and they are –
Required – For checking mandatory value.
Range – For checking the age range, age should be between the ranges.
Explain Page.IsValid?
This property will let you know whether all validation in a page succeeded or not.
State management
Ans:
State management is the process by which you maintain state and page information over
multiple requests for the same or different pages.
a. View State – Asp.Net uses View State to track the values in the Controls. You can add
custom values to the view state. It is used by the Asp.net page framework to automatically
save the values of the page and of each control just prior to rendering to the page. When
the page is posted, one of the first tasks performed by page processing is to restore view
state.
b. Control State – If you create a custom control that requires view state to work properly,
you should use control state to ensure other developers don’t break your control by
disabling view state.
c. Hidden fields – Like view state, hidden fields store data in an HTML form without
displaying it in the user's browser. The data is available only when the form is processed.
d. Cookies – Cookies store a value in the user's browser that the browser sends with every
page request to the same server. Cookies are the best way to store state data that must be
available for multiple Web pages on a web site.
e. Query Strings - Query strings store values in the URL that are visible to the user. Use
query strings when you want a user to be able to e-mail or instant message state data with
a URL.
b. Session State – Session State information is available to all pages opened by a user
during a single visit.
Both application state and session state information is lost when the application restarts. To
persist user data between application restarts, you can store it using profile properties.
Query string
What you mean by Query String? What are its advantages and limitations?
The Query String helps to send the page information to the server. Advantages of Query String are -
All browsers works with Query Strings.
Query String would not not require any server resources so it does not exert any sort of burden on the
server.
Limitations of Query String are -
Browser URL does not support many characters and it has limit.
Information will be visible to the user, which leads to security issues.
View state
What is view state?
The web is stateless. But in ASP.NET, the state of a page is maintained in the in the page itself
automatically. How? The values are encrypted and saved in hidden controls. this is done
automatically by the ASP.NET. This can be switched off / on for a single control
When the View state is saved, and when is it loaded? How to enable/ disable View
states?
A. View State data is stored in the current page in base64 encoded format. It gets
loaded with the page and displays the values to the controls after the decoded.
Internally it actually saves the check-sum of all the control data where the view
state is enabled.so that when the page gets loaded due to any post back, it again
finds the check-sum and then decodes the Base64 encoded string and gets back
the same data to the controls. We can see the view state base 64 encoded string in
View Source of the page. It will be like
_VIEWETATE="DSDSDF8DGDGDFGFD5FDGGDJFF23BNN457M9UJOG" this.
View state won't take the client or server memory to keep the view state data.
Hidden fields are best way for exchanging the data between client (browser) and server. These controls
are not visible in web page but can be accessed from javascript or Jquery.
What is the difference between Hidden Field and Textbox with Visible=false?
Hidden Field can be accessed from javascript or Jquery, whereas Textbox with Visible = false is not
accessible from javascript or Jquery.
This property is used to enable the ViewState property on the page. It is set to ON, to allow it to save the
input values of the user between postback requests. When is set to OFF, it won't allow to save the user
input in postbacks.
Yes we can store the dataset into viewstate. We have to serialize the dataset and store it into viewstate.
For large amount of data, Session will be an efficient way to go. When session is not used, set it to null
for memory overhead but this cannot be done in all the cases. Once the session timeout happened it
automatically set to null. Default timeout is 20 minutes.
In Viewstate, all data will be stored in HTML hidden fields. For large amount of data, it would give
performance issues. Ideal size of viewstate should not be more than 20-30% of page size. So for less
data viewstate will be an ideal solution
Cookies
Cookie.Discard Property when set true will instruct the client application not to save the Cookie on the
user’s hard disk when a session ends
Session
Below are the two ways used to send data across pages in ASP.NET –
Public properties
Session
How can I disable the Session at page level and at the application level?
Purpose of view state is to persist the state across postback. “EnableViewState” property is available at
control and page level. Once we set it to TRUE, viewstate for a Control/Page will be enabled.
Basically timeout of session is 20 minutes and if we want to change this timeout we can do in following
way –
Change the Session time out in web.config. (In sessionstate tag change the timeout)
Change the Session time out in code using timeout property of session class.
Application
What are the differences between Application object and session object?
Ans: The session object is used to maintain the session of each user. If one user enter in to
the application then they get session id if he leaves from the application then the session id
is deleted. If they again enter in to the application they get different session id.
But for application object the id is maintained for whole application.
Ans: Yes we can set the session out time manually in web.config.
Following are the Web Form Events in the sequence of their execution -
Page_Init
Page_Load
Page_PreRender
Page_Unload
Page_Disposed
Page_Error
Page_AbortTransaction
Page_CommitTransaction
Page_DataBinding
Ans: Browser understands an only html control that’s why in page rendering we will convert
the aspx controls into html controls.
Global.asax
What is the use of Global.asax ? and explain the events in Global.asax ?
It allows to executing ASP.NET application level events and setting application-level variables.
Application_Init
Application_Disposed
Application_Error
Application_Start
Application_End
Application_BeginRequest
Application_EndRequest
Application_PreRequestHandlerExecute
Application_PostRequestHandlerExecute
Applcation_PreSendRequestHeaders
Application_PreSendContent
Application_AuthenticateRequest
Application_AuthorizeRequest
Session_Start
Session_End
A web application starts, when a browser requests a page of the application for the first time. The
request will be received by the IIS which then starts ASP.NET worker process. The worker process then
allocates a process space to the assembly and loads it. An Application_Start() event will fire on start of
the application and it’s followed by Session_Start(). ASP.NET engine then processes the request and
sends back response in the form of HTML to the user and user receives the response in the form of
page.
Explain the application event handlers in ASP.NET ?
Caching
Cache – This improves the performance by minimizing the database hits to fetch the data. It instead
stores the data in cache. So cache will be checked first for data and if it is not found then go to database
to get the data.
Session – Session will be created to store the details of the user for capturing the user’s specific actions.
Session will be killed or it will be expired in 20 minutes.
In case in our application, we need to store large amount of data and if it is the master data (which does
not change most often) then we can use caching for storing this data.
There are six objects are there in ASP.NET and they are following –
Session
Request
Response
Object Request
Server
Application
What are the difference between adding the items into cache through the Add ()
method and through the Insert () method?
Cache.Add() will return an object that represents the item added in the cache.
Cache.Insert() is going to replace the existing item in the cache which will not happen in Cache.Add().
What are different types of caching using cache object of ASP.NET?
We can use two types of output caching to cache information that is to be transmitted to and displayed
in a Web browser –
Page Output Caching
Page Fragment Caching
Output caching
How can you cache different version of same page using cache in ASP.NET?
Output cache functionality is achieved by using “OutputCache” attribute on ASP.NET page header. It
uses following parameters –
VaryByParam - Caches different version depending on input parameters send through HTTP POST/GET.
VaryByHeader - Caches different version depending on the contents of the page header.
ASP.NET provides In-Process and Out-of-Process state management. In-Process will store the session in
memory on the web server. Out-of-Process will store data in an external data source such as SQL Server
or a State Server service. Out-of-Process requires that all objects stored in session are serializable.
User controls are easy to build, but they are less convenient to use in complicated scenarios. User
controls are developed in the same way as we develop Web Forms pages in the visual designer. User
controls can handle execution events.
Custom controls are compiled code, which makes them easier to use but difficult to create one. Once
you have created the control, we can add it to the Toolbox and display it in a visual designer. We can
deploy custom control in GAC and can be shared between the applications. This is either extended from
Control/WebControl class.
Master Page acts like a normal page. Master Pages can contain controls, code or markup as in web form.
Master page will have a control called “ContentPlaceHolder”, which defines region of master page which
renders HTML content of child pages which uses master page. Master pages will have extension
".master" and there will be a master directive at the top of the page as shown below -
<%@ Master Language="C#" AutoEventWireup="true" CodeFile="TestOurSite.master.cs" Inherits="
TestOurSite " %>
As content page, sub master page will not be having complete HTML source code. But at top level
master page unlike sub master page it will have complete HTML source code in source file.
Using page events we can change the master page during runtime. In Page_PreInit() event we can
change the master page by setting the “MasterPageFile” property to the path of the master page what
we have to set.
A content page would not be having the complete HTML source code; whereas a master page has
complete HTML source code inside its source file.
Login controls encapsulate all the features offered by Forms authentication. Login controls internally use
Forms Authentication class to implement security, by prompting for user credentials validating them.
Declaration of authorization is
<authorization>
<allow users=”Suresh, Sanjay”/>
<deny users=”Ramana, Rakesh”>
</authorization>
Sometimes authorization allows the unauthorized persons at that time we will use
<deny users=”?”/>
Authentication means
Authentication is the process in which we are checking the identity of the user to allow the user into the
application. So Login is the process of authentication for the application. Now social media
authentication is also allowed in many websites to identify the user.
Authorization sounds same as authentication but it is different. Authorization handles the permission
stuff for the user at web page level. Better example will be if the user is authenticated in the website
does not mean that user has full permission on all the pages so that can be controlled by authorization.
CustomError tag gives the details of custom error messages. CustomError tag can be defined at any level
in application file hierarchy.
<configuration>
<system.web>
<customErrors mode="RemoteOnly" defaultRedirect="A4academicsError.html"/>
</system.web>
</configuration>
As you can see above customError section has attribute - "defaultRedirect", which specifies the default
redirection.
Yes. We can have multiple web.config in an application. But these web.config files should be under
different folders, it should not be in same place in an application.
Web.config file defines configuration for a web project. Using “AppSetting” section we can define user
defined values. Rather than hard coding the values in an application, developers prefer to keep the
key,value pair in appsettings. Below is the sample for adding key value pair–
<appSettings>
<add key = “yourkey” value=”yourvalue”/>
</appSettings>
ASP.NET membership allows you to store and validate the user credentials. Forms Authentication can be
used for storing the user credentials in ASP.NET membership using login controls of ASP.NET.
Membership supports storing user credentials in SQL Server , Active Directory etc.
Internet Information Services (IIS) is created by Microsoft to provide Internet-based services to ASP.NET
Web applications. It makes your system to work as a Web server and provides the functionality to
develop and deploy Web applications on the server. IIS handles the request-response cycle on the Web
server. It offers the service of SMTP and front-page server extensions. As you know SMTP is used to send
emails and use FrontPage server extensions to get the dynamic features of IIS, such as form handlers.
Navigation controls will be used to navigate in a Web application. These controls will store the links
either in hierarchical structure or drop-down structure. Navigation controls available in ASP.NET are –
Tree View
Menu
Sitemap Path
ASP.net with C#
JavaScript works from the client side while server code requires server processing. It is not possible to di
rectly invoke a client event through a server event. However there exists a
fairly simple methods to achieve this. I will explain one simple way to do it.
This is one of the simplest method to call a JavaScript function from code behind. You need to do
the following:
<body>
<form id="form1" runat="server">
<div>
<asp:Label ID="lblJavaScript" runat="server" Text=""></asp:Label>
<asp:Button ID="btnShowDialogue" runat="server" Text="Show Dialogue" />
</div>
</form>
</body>
4. Add a javascript function to show a message box as shown below:
<head runat="server">
<title>Calling javascript function from code behind example</title>
<script type="text/javascript">
function showDialogue()
{
alert("this dialogue has been invoked through codebehind.");
}
</script>
</head>
5. Now double-click on the button and add the following code:
lblJavaScript.Text = "<script type='text/javascript'> showDialogue(); </script>";
6. Run your project and click the Show Dialogue button
7. A message box will be displayed as shown below: