Interview questions for asp.net
1.Difference
between thread and process?
Thread
- is used to execute more than one program at a time.
process - executes single program
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)
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()
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
@ 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
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.
* 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.
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
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.
No comments:
Post a Comment