1.
|
Difference between thread and
process?
|
|
Thread - is used to execute more
than one program at a time.
process - executes single program
|
2.
|
Explain Namespace.
|
|
Namespaces are logical groupings
of names used within a program. There may be multiple namespaces in a single
application code, grouped based on the identifiers’ use. The name of any
given identifier must appear only once in its namespace.
|
3.
|
List the types of Authentication
supported by ASP.NET.
|
|
Windows (default)
Forms
Passport
None (Security disabled)
|
4.
|
What is CLR?
|
|
Common Language Runtime (CLR) is a
run-time environment that manages the execution of .NET code and provides
services like memory management, debugging, security, etc. The CLR is also
known as Virtual Execution System (VES).
|
5.
|
What is CLI?
|
|
The CLI is a set of specifications
for a runtime environment, including a common type system, base class
library, and a machine-independent intermediate code known as the Common
Intermediate Language (CIL).
|
6.
|
List the various stages of
Page-Load lifecycle.
|
|
o Init()
o Load()
o PreRender()
o Unload()
|
7.
|
Explain Assembly and Manifest.
|
|
An assembly is a collection of one
or more files and one of them (DLL or EXE) contains a special metadata called
Assembly Manifest. The manifest is stored as binary data and contains details
like versioning requirements for the assembly, the author, security
permissions, and list of files forming the assembly. An assembly is created
whenever a DLL is built. The manifest can be viewed programmatically by
making use of classes from the System.Reflection namespace. The tool
Intermediate Language Disassembler (ILDASM) can be used for this purpose. It
can be launched from the command prompt or via Start> Run.
|
8.
|
What is Shadow Copy?
|
|
In order to replace a COM
component on a live web server, it was necessary to stop the entire website,
copy the new files and then restart the website. This is not feasible for the
web servers that need to be always running. .NET components are different.
They can be overwritten at any time using a mechanism called Shadow Copy. It
prevents the Portable Executable (PE) files like DLLs and EXEs from being
locked. Whenever new versions of the PEs are released, they are automatically
detected by the CLR and the changed components will be automatically loaded.
They will be used to process all new requests not currently executing, while the
older version still runs the currently executing requests. By bleeding out
the older version, the update is completed.
|
9.
|
What is DLL Hell?
|
|
DLL hell is the problem that
occurs when an installation of a newer application might break or hinder
other applications as newer DLLs are copied into the system and the older
applications do not support or are not compatible with them. .NET overcomes
this problem by supporting multiple versions of an assembly at any given
time. This is also called side-by-side component versioning.
|
10.
|
Explain Web Services.
|
|
Web services are programmable
business logic components that provide access to functionality through the
Internet. Standard protocols like HTTP can be used to access them. Web
services are based on the Simple Object Access Protocol (SOAP), which is an
application of XML. Web services are given the .asmx extension.
|
11.
|
Explain Windows Forms.
|
|
Windows Forms is employed for
developing Windows GUI applications. It is a class library that gives
developers access to Windows Common Controls with rich functionality. It is a
common GUI library for all the languages supported by the .NET Framework.
|
12.
|
What is Postback?
|
|
When an action occurs (like button
click), the page containing all the controls within the <FORM... > tag
performs an HTTP POST, while having itself as the target URL. This is called
Postback.
|
13.
|
Explain the differences between
server-side and client-side code?
|
|
Server side scripting means that
all the script will be executed by the server and interpreted as needed.
Client side scripting means that the script will be executed immediately in
the browser such as form field validation, clock, email validation, etc.
Client side scripting is usually done in VBScript or JavaScript. Since the
code is included in the HTML page, anyone can see the code by viewing the
page source. It also poses as a possible security hazard for the client
computer.
|
14.
|
Enumerate the types of Directives.
|
|
@ Page directive
@ Import directive
@ Implements directive
@ Register directive
@ Assembly directive
@ OutputCache directive
@ Reference directive
|
|
|
15.
|
What is
Code-Behind?
|
|
Code-Behind
is a concept where the contents of a page are in one file and the server-side
code is in another. This allows different people to work on the same page at
the same time and also allows either part of the page to be easily
redesigned, with no changes required in the other. An Inherits attribute is
added to the @ Page directive to specify the location of the Code-Behind file
to the ASP.NET page.
|
16.
|
Describe
the difference between inline and code behind.
|
|
Inline
code is written along side the HTML in a page. There is no separate
distinction between design code and logic code. Code-behind is code written
in a separate file and referenced by the .aspx page.
|
17.
|
List the
ASP.NET validation controls?
|
|
RequiredFieldValidator
RangeValidator
CompareValidator
RegularExpressionValidator
CustomValidator
ValidationSummary
|
18.
|
What is
Data Binding?
|
|
Data
binding is a way used to connect values from a collection of data (e.g.
DataSet) to the controls on a web form. The values from the dataset are
automatically displayed in the controls without having to write separate code
to display them.
|
19.
|
Describe
Paging in ASP.NET.
|
|
The
DataGrid control in ASP.NET enables easy paging of the data. The AllowPaging
property of the DataGrid can be set to True to perform paging. ASP.NET
automatically performs paging and provides the hyperlinks to the other pages
in different styles, based on the property that has been set for
PagerStyle.Mode.
|
20.
|
Should
user input data validation occur server-side or client-side? Why?
|
|
All user input data validation
should occur on the server and minimally on the client-side, though it is a
good way to reduce server load and network traffic because we can ensure that
only data of the appropriate type is submitted from the form. It is totally
insecure. The user can view the code used for validation and create a
workaround for it. Secondly, the URL of the page that handles the data is
freely visible in the original form page. This will allow unscrupulous users
to send data from their own forms to your application. Client-side validation
can sometimes be performed where deemed appropriate and feasible to provide a
richer, more responsive experience for the user.
|
21.
|
What is the difference between
Server.Transfer and Response.Redirect?
|
|
* Response. Redirect: This tells
the browser that the requested page can be found at a new location. The
browser then initiates another request to the new page loading its contents
in the browser. This results in two requests by the browser.
* Server. Transfer: It transfers execution from the first page to the second
page on the server. As far as the browser client is concerned, it made one
request and the initial page is the one responding with content. The benefit
of this approach is one less round trip to the server from the client
browser. Also, any posted form variables and query string parameters are
available to the second page as well.
|
22.
|
What is an interface and what is
an abstract class?
|
|
In an interface, all methods must
be abstract (must not be defined). In an abstract class, some methods can be
defined. In an interface, no accessibility modifiers are allowed, whereas it
is allowed in abstract classes.
|
23.
|
Session state vs. View state:
|
|
In some cases, using view state is
not feasible. The alternative for view state is session state. Session state
is employed under the following situations:
o Large amounts of data - View state tends to increase the size of both the
HTML page sent to the browser and the size of form posted back. Hence session
state is used.
o Secure data - Though the view state data is encoded and may be encrypted,
it is better and secure if no sensitive data is sent to the client. Thus,
session state is a more secure option.
o Problems in serializing of objects into view state - View state is
efficient for a small set of data. Other types like DataSet are slower and
can generate a very large view state.
|
24.
|
Can two different programming
languages be mixed in a single ASPX file?
|
|
ASP.NET’s built-in parsers are
used to remove code from ASPX files and create temporary files. Each parser
understands only one language. Therefore mixing of languages in a single ASPX
file is not possible.
|
25.
|
Is it possible to see the code
that ASP.NET generates from an ASPX file?
|
|
By enabling debugging using a
<%@ Page Debug="true" %> directive in the ASPX file or a
<compilation debug="true"> statement in Web.config, the
generated code can be viewed. The code is stored in a CS or VB file (usually
in the \%SystemRoot%\Microsoft.NET\Framework\v1.0.nnnn\Temporary ASP.NET
Files).
|
26.
|
Can a custom .NET data type be
used in a Web form?
|
|
This can be achieved by placing
the DLL containing the custom data type in the application root's bin
directory and ASP.NET will automatically load the DLL when the type is
referenced.
|
27.
|
List the event handlers that can
be included in Global.asax?
|
|
o Application start and end event
handlers
o Session start and end event handlers
o Per-request event handlers
o Non-deterministic event handlers
|
28.
|
Can the view state be protected
from tampering?
|
|
This can be achieved by including
an @ Page directive with an EnableViewStateMac="true" attribute in
each ASPX file that has to be protected. Another way is to include the
<pages enableViewStateMac="true" /> statement in the
Web.config file.
|
29.
|
Can the view state be encrypted?
|
|
The view state can be encrypted by
setting EnableViewStateMac to true and either modifying the
<machineKey> element in Machine.config to <machineKey validation="3DES”
/> or by adding the above statement to Web.config.
|
30.
|
When during the page processing
cycle is ViewState available?
|
|
The view state is available after
the Init() and before the Render() methods are called during Page load.
|