Saturday, 30 August 2014

Design Patterns used in Spring Framework:


Spring Framework implemented on the layered architecture implements a good number of patterns.
1. Creational Patterns
a) Singleton – Beans defined in spring config files(xml) are only created once by default. No matter how many calls were made using getBean() method, it will always have only one bean. This is because, by default all beans in spring are singletons. This can be overridden by using Prototype bean scope.Then spring will create a new bean object for every request.
Example:
<bean id=”employee” class=”com.ranga.Employee” scope="singleton”/>
b) Factory - Spring uses factory pattern to create objects of beans using BeanFactory and Application Context reference.
// Spring uses factory pattern to create instances of the objects
BeanFactory factory=new XmlBeanFactory(new ClassPathResource("beans.xml"));
Employee employee = (Employee) factory.getBean("employee");
System.out.println(employee);

c) Prototype – This is about creating or cloning a new instance whenever required; Spring Framework implements this pattern as part of bean scoping.
Example:
<bean id=”employee” class=”com.ranga.Employee” scope="prototype”/>
d) Builder - Spring provides programmatic means of constructing BeanDefinitions using the builder pattern through Class "BeanDefinitionBuilder".
2. Behavioural Patterns
a) Template – Used extensively to deal with boilerplate repeated code (such as closing connections cleanly, etc). Spring framework implemented this pattern for variety of features like, JmsTemplate, JDBCTemplate.
Example:
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" scope="prototype">
            <constructor-arg ref="dataSource" />
</bean>

b) Mediator – Please jump to Front Controller.
3. Structural Patterns
a) Proxy – This pattern is useful to control the access to an object and expose the same interface as that of that object. Spring framework implements this pattern in its AOP support.
Please refer this link.
4. J2EE Patterns
a) Front Controller - Spring provides "DispatcherServlet" to ensure an incoming request gets dispatched to your controllers.
b) DAO Pattern – this pattern is about abstracting the database access. This pattern is implemented in Spring framework in its DAO module.
Example:
<bean id="abstractJdbcDao" abstract="true" class="org.springframework.jdbc.core.support.JdbcDaoSupport">
<property name="dataSource" ref="dataSource"/>
</bean>

c) Model View Controller - The advantage with Spring MVC is that your controllers are POJOs as opposed to being servlets. This makes for easier testing of controllers. One thing to note is that the controller is only required to return a logical view name, and the view selection is left to a separate ViewResolver. This makes it easier to reuse controllers for different view technologies.
d) View Helper - Spring has a number of custom JSP tags, and velocity macros, to assist in separating code from presentation in views.

Wednesday, 27 August 2014

UNDERSTANDING SPRING MVC MODEL AND SESSION ATTRIBUTES


As a Java Web application developer, you quickly learn about the request (HttpServletRequest) and session (HttpSession) scopes.  Understanding these scopes and how to work data and objects in and out of these scopes is critical to designing and building Web applications in Java.  [For a quick tutorial on request and session scopes, here is a post in StackOverflow that can help.]SPRING MVC SCOPES
When I started writing Web applications in Spring MVC, I found the Spring model and session attributes to be a bit of a mystery – especially as they relate to the HTTP request and session scopes and their attributes that I knew well.  Was a Spring model element going to be found in my session or request?  If so, how could I control this?  In this post, I hope to demystify how Spring MVC’s model and session work.
SPRING’S @MODELATTRIBUTE
There are several ways to add data or objects to Spring’s model.  Data or objects are typically added to Spring’s model via an annotated method in the controller.  In the example below, @ModelAttribute is used to add an instance of MyCommandBean to the model under the key of “myRequestObject”.

@Controllerpublic class MyController {     @ModelAttribute("myRequestObject")    public MyCommandBean addStuffToRequestScope() {        System.out.println("Inside of addStuffToRequestScope");        MyCommandBean bean = new MyCommandBean("Hello World",42);        return bean;    }     @RequestMapping("/dosomething")    public String requestHandlingMethod(Model model, HttpServletRequest request) {        System.out.println("Inside of dosomething handler method");         System.out.println("--- Model data ---");        Map modelMap = model.asMap();        for (Object modelKey : modelMap.keySet()) {            Object modelValue = modelMap.get(modelKey);            System.out.println(modelKey + " -- " + modelValue);        }         System.out.println("=== Request data ===");        java.util.Enumeration reqEnum = request.getAttributeNames();        while (reqEnum.hasMoreElements()) {            String s = reqEnum.nextElement();            System.out.println(s);            System.out.println("==" + request.getAttribute(s));        }         return "nextpage";    }          //  ... the rest of the controller}On an incoming request, any methods annotated with @ModelAttribute are called before any controller handler method (like requestHandlingMethod in the example above).  These methods add data to a java.util.Map that is added to the Spring model before the execution of the handler method.  This can be demonstrated by a simple experiment.  I created two JSP pages:  index.jsp and nextpage.jsp.  A link on index.jsp page is used to send a request into the application triggering the requestHandlingMethod() of MyController.  Per the code above, the requestHandlingMethod() returns “nextpage” as the logical name of the next view which is resolved to nextpage.jsp in this case.
modeldataexampleInside of addStuffToRequestScopeInside of dosomething handler method--- Model data ---myRequestObject -- MyCommandBean [someString=Hello World, someNumber=42]=== Request data ===org.springframework.web.servlet.DispatcherServlet.THEME_SOURCE==WebApplicationContext for namespace 'dispatcher-servlet': startup date [Sun Oct 13 21:40:56 CDT 2013]; root of context hierarchyorg.springframework.web.servlet.DispatcherServlet.THEME_RESOLVER==org.springframework.web.servlet.theme.FixedThemeResolver@204af48corg.springframework.web.servlet.DispatcherServlet.CONTEXT==WebApplicationContext for namespace 'dispatcher-servlet': startup date [Sun Oct 13 21:40:56 CDT 2013]; root of context hierarchyorg.springframework.web.servlet.HandlerMapping.pathWithinHandlerMapping==dosomething.requestorg.springframework.web.servlet.HandlerMapping.bestMatchingPattern==/dosomething.*org.springframework.web.servlet.DispatcherServlet.LOCALE_RESOLVER==org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver@18fd23e4Now, the question is “where is Spring model data stored?”  Is it stored in the standard Java request scope?  The answer is – yes… eventually.  As you can tell from the output above, MyCommandBean is in the model, but not yet in the request object when the handler method executes.  Indeed, Spring does not add the model data to the request as an attribute until after the execution of the handler method and before presentation of the next view (in this case the nextpage.jsp).
modeltorequest
This can also be demonstrated by printing out the attribute data stored in the HttpServletRequest in both index.jsp and nextpage.jsp.  I arranged for both of these pages to use a JSP scriptlet (shown below) to display the HttpServletRequest attributes.

<hr /><h3>Request Scope (key==values)</h3><%    java.util.Enumeration<String> reqEnum = request.getAttributeNames();    while (reqEnum.hasMoreElements()) {        String s = reqEnum.nextElement();        out.print(s);        out.println("==" + request.getAttribute(s));%><br /><%    }%>When the application comes up and index.jsp is displayed, you can see that there are no attributes in request scope.
Request Attributes Before
In this case, when the “do something” link is clicked it causes the MyController’s handler method to execute, which in turn causes the nextpage.jsp to be displayed.  Given the same JSP scriptlet is on the nextpage.jsp, it too renders what is in the request scope.  Lo and behold, when nextpage.jsp renders, it shows the model MyCommandBean created in the controller has been added to the HttpServletRequest scope!  The Spring model attribute key of “myRequestObject” has even been copied and used as the request attribute’s key.
requestattributesafterSo Spring model data created prior to (or during) the handler method execution has been copied to the HttpServletRequest before the next view is rendered.
REASON BEHIND SPRING MODEL VERSUS REQUEST
You may wonder why Spring uses model attributes.  Why not just add data directly to the request object?  I found the answer to this question in Rod Johnson et. al’s book Professional Java Development with the Spring Framework.  This book is a little dated with regard to the Spring API (written to Spring 2.0), but I have always found the text provide a little more explanation of what’s going on under the covers of the Spring engine.  Here is the quote from that text regarding model elements:
“…adding elements directly to the HttpServletRequest (as request attributes) would seem to serve the same purpose.  The reason to do this is obvious when taking a look at one of the requirements we have set for the MVC framework:  It should be as view-agnostic as possible, which means we’d like to be able to incorporate view technologies not bound to the HttpServletRequest as well.” (page 429-430)SPRING’S @SESSIONATTRIBUTES
So now you know how Spring’s model data is managed and how it relates to regular Http request attribute data.  What about Spring’s session data?
Spring’s @SessionAttributes is used on a controller to designate which model attributes should be stored in the session.  Actually, to be precise, the Spring documentation states that the @SessionAttributes annotation “list the names of model attributes which should be transparently stored in the session or some conversational storage.”  Again, the “some conversational storage” suggests how Spring MVC tries to remain technology agnostic it is design.
In actually, what @SessionAttributes allows you to do is tell Spring which of your model attributes will also be copied to HttpSession before rendering the view.  Again, this can be demonstrated with a little code.
In my index.jsp and nextpage.jsp, I added an additional JSP scriptlet to show the HttpSession attributes.

<h3>Session Scope (key==values)</h3><%  java.util.Enumeration<String> sessEnum = request.getSession()    .getAttributeNames();  while (sessEnum.hasMoreElements()) {    String s = sessEnum.nextElement();    out.print(s);    out.println("==" + request.getSession().getAttribute(s));%><br /><%  }%>I annotated MyController with @SessionAttributes to put the same model attribute (myRequestObject) in Spring session.@Controller@SessionAttributes("myRequestObject")public class MyController {  ...}I also added code to the handler method of my controller to show what attributes are in HttpSession (just as it shows what attributes are in HttpServletRequest).
@SuppressWarnings("rawtypes")@RequestMapping("/dosomething")public String requestHandlingMethod(Model model, HttpServletRequest request, HttpSession session) {  System.out.println("Inside of dosomething handler method");   System.out.println("--- Model data ---");  Map modelMap = model.asMap();  for (Object modelKey : modelMap.keySet()) {    Object modelValue = modelMap.get(modelKey);    System.out.println(modelKey + " -- " + modelValue);  }   System.out.println("=== Request data ===");  java.util.Enumeration<String> reqEnum = request.getAttributeNames();  while (reqEnum.hasMoreElements()) {    String s = reqEnum.nextElement();    System.out.println(s);    System.out.println("==" + request.getAttribute(s));  }   System.out.println("*** Session data ***");  Enumeration<String> e = session.getAttributeNames();  while (e.hasMoreElements()){    String s = e.nextElement();    System.out.println(s);    System.out.println("**" + session.getAttribute(s));  }   return "nextpage";}So now, we should be able to see what is in the session object before, during, and after Spring MVC has handled one HTTP request when annotated with @SessionAttributes.  The results are shown below.  First, as the index.jsp page is displayed (before the request is sent and handled by Spring MVC), we see that there is no attribute data in either the HttpServletRequest or HttpSession.Request and Session attributes before requestDuring the execution of the handler method (requestHandlingMethod), you see MyCommandBean has been added to the Spring model attributes, but it is not yet in the HttpServletRequest or HttpSession scope.During handler method executionBut after the handler method has executed and when the nextpage.jsp is rendered, you can see that the model attribute data (MyCommandBean) has indeed been copied as an attribute (with the same attribute key) to both HttpServletRequest and HttpSession.HttpSession and HttpServletRequest attributes after handler method completes
CONTROLLING SESSION ATTRIBUTES
So now you have an appreciation of how Spring model and session attribute data are added to HttpServletRequest and HttpSession. But now you may be concerned with how to manage that data in Spring session. Spring provides a means to remove Spring session attributes, and thereby also remove it from HttpSession (without having to kill the entire HttpSession). Simply add a Spring SessionStatus object as a parameter to a controller handler method. In this method, use the SessionStatus object to end the Spring session.
@RequestMapping("/endsession")public String nextHandlingMethod2(SessionStatus status){  status.setComplete();  return "lastpage";}WRAP UP
So hopefully, this post has helped you understand Spring model and session attributes.  Its not magic, its just a matter of understanding how HttpSession and HttpServletRequest are used to store Spring model and session attributes.  I have placed the code demonstrated here on the Intertech Web site.  If you are interested in using it to explore and understand Spring model and session, feel free to download it from here.
If you are interested in learning Spring (or any Java topic) further, think about signing up for a class at Intertech today.  Learn more and sign up here.


Read more: http://www.intertech.com/Blog/understanding-spring-mvc-model-and-session-attributes/#ixzz3BZjSr0S7 Follow us: @IntertechInc on Twitter | Intertech on Facebook

Saturday, 23 August 2014

ASP MVC FAQ




MVC stands for Model View Controller.
It divides an application into 3 component roles which is based on a framework methodology.
These component roles are discussed briefly as follows:

i) Models : These component roles are used to maintain the state which is persisted inside the Database.

Example: we might have a Product class that is used to represent order data from the Products table inside SQL.

ii) Views : These component roles are used to display the user interface of the application, where this UI is created off of the model data.

Example: we might create an Product “Edit” view that surfaces textboxes, dropdowns and checkboxes based on the current state of a Product object.

iii) Controllers : These component roles are used for various purposes like handling end user interaction, manipulating the model, and ultimately choosing a view to render to display UI.

Note:

In a MVC application, the views are used only for displaying the information whereas the controllers are used for handling and responding to user input and interaction.


The MVC framework is defined through System.Web.Mvc assembly.
This is because this is the only assembly which contains classes and interfaces that support the ASP.NET Model View Controller (MVC) framework for creating Web applications.


We can combine ASP.NET MVC into an existing ASP.NET application by following the below procedure:

First of all, you have to add a reference to the following three assemblies to your existing ASP.NET application:

i) System.Web.Routing
ii) System.Web.Abstractions
iii) System.Web.Mvc

The ASP.NET MVC folder should be created after adding these assembly references.
Add the folder Controllers, Views, and Views | Shared to your existing ASP.NET application.
And then you have to do the necessary changes in web.config file.
For this you can refer to the below link:

http://www.packtpub.com/article/mixing-aspnet-webforms-and-aspnet-mvc


The main advantages of using asp.net mvc are as follows:

i) One of the main advantage is that it will be easier to manage the complexity as the application is divided into model,view and controller.
ii) It gives us the full control over the behavior of an application as it does not use view state or server-based forms.
iii) It provides better support for test-driven development (TDD).
iv) You can design the application with a rich routing infrastructure as it uses a Front Controller pattern that processes Web application requests through a single controller.


This Razor View engine is a part of new rendering framework for ASP.NET web pages.
ASP.NET rendering engine uses opening and closing brackets to denote code (<% %>), whereas Razor allows a cleaner, implied syntax for determining where code blocks start and end.

Example:

In the classic renderer in ASP.NET:


<ul>

<% foreach (var userTicket in Model)

  { %>

    <li><%: userTicket.Value %></li>

<%  } %>

</ul>



By using Razor:


<ul>

@foreach (var userTicket in Model)

{

  <li>@userTicket.Value</li>

}

</ul>



In an MVC application, all the features are based on interface. So, it is easy to unit test a MVC application.
And it is to note that, in MVC application there is no need of running the controllers for unit testing.


System.Web.Mvc namespace contains all the interfaces and classes which supports ASP.NET MVC framework for creating web applications.


Yes, It is possible to share a view across multiple controllers by putting a view into the shared folder.
By doing like this, you can automatically make the view available across multiple controllers.


A controller will decide what to do and what to display in the view. It works as follows:

i) A request will be received by the controller
ii) Basing on the request parameters, it will decide the requested activities
iii) Basing on the request parameters, it will delegates the tasks to be performed
iv) Then it will delegate the next view to be shown


An action method is used to return an instance of any class which is derived from ActionResult class.
Some of the return types of a controller action method are:
i) ViewResult : It is used to return a webpage from an action method
ii) PartialViewResult : It is used to send a section of a view to be rendered inside another view.
iii) JavaScriptResult : It is used to return JavaScript code which will be executed in the user’s browser.
iv) RedirectResult : Based on a URL, It is used to redirect to another controller and action method.
v) ContentResult : It is an HTTP content type may be of text/plain. It is used to return a custom content type as a result of the action method.
vi) JsonResult : It is used to return a message which is formatted as JSON.
vii) FileResult : It is used to send binary output as the response.
viii) EmptyResult : It returns nothing as the result.


The page lifecycle of an ASP.NET MVC page is explained as follows:

i) App Initialisation
In this stage, the aplication starts up by running Global.asax’s Application_Start() method.
In this method, you can add Route objects to the static RouteTable.Routes collection.
If you’re implementing a custom IControllerFactory, you can set this as the active controller factory by assigning it to the System.Web.Mvc.ControllerFactory.Instance property.

ii) Routing
Routing is a stand-alone component that matches incoming requests to IHttpHandlers by URL pattern.
MvcHandler is, itself, an IHttpHandler, which acts as a kind of proxy to other IHttpHandlers configured in the Routes table.

iii) Instantiate and Execute Controller
At this stage, the active IControllerFactory supplies an IController instance.

iv) Locate and invoke controller action
At this stage, the controller invokes its relevant action method, which after further processing, calls RenderView().

v) Instantiate and render view
At this stage, the IViewFactory supplies an IView, which pushes response data to the IHttpResponse object.


It is already known that all the public methods of a controller class are basically treated as action methods.
If you dont want this default behaviour, then you can change the public method with NonActionAttribute. Then, the default behaviour changes.


The Router Table is formed by following the below procedure:

In the begining stage, when the ASP.NET application starts, the method known as Application_Start() method is called.
The Application_Start() will then calls RegisterRoutes() method.
This RegisterRoutes() method will create the Router table.


There are 3 segments of the default route in an MVC application.They are:

The 1st segment is the Controller Name.
Example: search

The 2nd segment is the Action Method Name.
Example: label

The 3rd segment is the Parameter passed to the Action method.
Example: Parameter Id - MVC


The settings must be done in 2 places for the routing to work properly.They are:

i) Web.Config File : In the web.config file, the ASP.NET routing has to be enabled.
ii) Global.asax File : The Route table is created in the application Start event handler, of the Global.asax file.


To avoid xss vulnerabilities, you have to use the syntax as '<%: %>' in ASP.NET MVC instead of using the syntax as '<%= %>' in .net framework 4.0.
This is because it does the HTML encoding.

Example:


<input type="text" value="<%: value%>" />



Without using Routing in an ASP.NET MVC application, the incoming browser request should be mapped to a physical file.The thing is that if the file is not there, then you will get a page not found error.
By using Routing, it will make use of URLs where there is no need of mapping to specific files in a web site.
This is because, for the URL, there is no need to map to a file, you can use URLs that are descriptive of the user's action and therefore are more easily understood by users.


There are 3 things that are required to specify a route.

i) URL Pattern : You can pass the variable data to the request handler without using a query string. This is done by including placeholders in a URL pattern.
ii) Handler : This handler can be a physical file of 2 types such as a .aspx file or a controller class.
iii) Name for the Route : This name is an optional thing.
ASP.NET MVC Interview Questions and Answers (110) - Page 2
Now you don't need go anywhere to get the best interview questions on Microsoft technology. We are trying to gather all real interview questions asked from MNCs and put them here. You can also assist us in doing so by submitting .net interview questions. These questions are generally different from certification questions however it may help you in that too.

110 records found. 

Description: Page copy protected against web site content infringement by Copyscape


{controller}{action}/{id} is not a valid route definition.
 
The reason is that, it has no literal value or delimiter between the placeholders.
 
If there is no literal, the routing cannot determine where to seperate the value for the controller placceholder from the value for the action placeholder.


With the help of this default route {resource}.axd/{*pathInfo}, you can prevent requests for the web resources files such as WebResource.axd or ScriptResource.axd from being passed to a controller.


We use MapPageRoute() method of a RouteCollection class for adding routes to a webforms application, whereas MapRoute() method is used to add routes to an MVC application.


You can handle variable number of segments in a route definition by using a route with a catch-all parameter.
 
Example:
 

controller/{action}/{*parametervalues}
 

Here * reffers to catch-all parameter.


There are 2 ways for adding constraints to a route. They are:
 
i) By using Regular Expressions and
 
ii) By using an object which implements IRouteConstraint interface.


Below are the 2 scenarios where routing is not applied.
 

i) A Physical File is Found that Matches the URL Pattern - This default behaviour can be overriden by setting the RouteExistingFiles property of the RouteCollection object to true.
 
ii) Routing Is Explicitly Disabled for a URL Pattern - By using the RouteCollection.Ignore() method, you can prevent routing from handling certain requests.


Action filter in an mvc application is used to perform some additional processing, such as providing extra data to the action method, inspecting the return value, or canceling execution of the action method.
 
Action filter is an attribute that implements the abstract FilterAttribute class.


As there are different types of filters in an MVC application, the Authorization filter is the one which executes first and Exeption filters executes in the end.


Both are used to pass the data from controllers to views.
 
The difference between Viewbag and Viewdata in ASP.NET MVC is explained below:
 

View Data:
 
In this, objects are accessible using strings as keys.
 

Example:
 

In the Controller:
 
public ActionResult Index()
{
var softwareDevelopers = new List<string>
{
"Brendan Enrick",
"Kevin Kuebler",
"Todd Ropog"
};
ViewData["softwareDevelopers"] = softwareDevelopers;
return View();
}

In the View:
<ul>
@foreach (var developer in (List<string>)ViewData["softwareDevelopers"])
{
<li>
@developer
</li>
}
</ul>

An important note is that when we go to use out object on the view that we have to cast it since the ViewData is storing everything as object.
 

View Bag:
 
It will allow the objectto dynamically have the properties add to it.
 

Example:
 

In the Controller:
 
public ActionResult Index()
{
var softwareDevelopers = new List<string>
{
"Brendan Enrick",
"Kevin Kuebler",
"Todd Ropog"
};
ViewBag.softwareDevelopers = softwareDevelopers;
return View();
}

In the View:
<ul>
@foreach (var developer in ViewBag.softwareDevelopers)
{
<li>
@developer
</li>
}
</ul>

An important point to note is that there is no need to cast our object when using the ViewBag. This is because the dynamic we used lets us know the type.


There are two types of file extensions for razor views.
 
They are:
 

i) .cshtml : This file extension is used, when the programming language is a C#.
 
ii) .vbhtml : This file extension is used, when the programming language is a VB.


In razor syntax, we use the below shown symbols for specifying comments.
 

i) For indicating the begining of a comment, we use @* syntax.
 
ii) For indicating the end of a comment, we use *@ syntax.


In ASP.NET MVC, validation helpers are used to show the validation error messages in a view.
 
The Html.ValidationMessage() and Html.ValidationSummary() helpers are used in the automatically generated Edit and Create views by the ASP.NET MVC.
 
To create a view, the following steps are to be followed:
 

i) In the product controller,right click on the Create() action and then select the option Add View.
 
ii) Now check the checkbox labeled in the Add View dialog and create a strongly-typed view.
 
iii) Select the product class from the View data class dropdownlist.
 
iv) Now, select Create from the view content dropdownlist.
 
v) Finally, click on the Add button.


No, It is not possible to create a MVC Unit Test application in Visual Studio Standard.
 
It is also not possible to create in Visual Studio Express.
 
It is possible to create only in Visual Studio Professional and Visual Studio Enterprise Versions.


It is an Open Source platform for gathers and presents detailed diagnostic information about the execution of your web application.It tells you exactly what's going on with each request.
 

We used in a similar manner to client side diagnostics and debugging tools like FireBug or Chrome Developer Tools.
 

It is used to reveal what is happening within your ASP.NET MVC and WebForms sites.








By default, visual studio doesn't provide Jquery intellisense support, but it can be achieved by adding vsdoc.js file to razor view.
 

@if(false)
 
{
 
<script src="~/script/jquery-1.7.1-vsdoc.js" type="text/javascript"></script>
 
}
 

No
 te : If statement prevents the rendering of script tag into the Html source code and it used only by visual studio for Jquery intellisense support.


1. Asp.net Webform follows an event-driven development model whereas Asp.net Mvc follow Model, View, Controller design pattern. 

2. Asp.net Webform has server controls whereas Asp.net Mvc has Html helpers for creating UI of application. 

3.Asp.net Webforms has state management techniques whereas Asp.net Mvc doesn't have automatic state management techniques. 

4. Asp.net Webform has file- based Urls means file name exists in Url whereas Asp.net Mvc has route-based Url. 

5. In Asp.net webform, webforms(Aspx) are tightly coupled to code-behind (Aspx.cs) whereas in Asp.net Mvc, Views and logic are kept separately. 

6. Asp.net Webform has Master page for consistent look and feel whereas in Asp.net Mvc layout is for this. 

7. Asp.net Webform has User Controls for code re-usability whereas in Asp.net Mvc partial view is for this.


A partial view is like as user control in Asp.Net web form. Partial views are reusable views like as Header and Footer. It has .csHtml extension.
 
Partial and RenderPartial Html method renders partial view in Mvc razor.
 

<div>@Html.Partial("_Comments")</div>
 
<div>@ { Html.RenderPartial("_Comments") } </div>


Strongly type view is used for rendering specific type of model object. By specifying the type of data we get intellisense for that model class. View inherits from Viewpage whereas strongly typed view inherits from Viewpage<T> where T is type of the model.
ASP.NET MVC Interview Questions and Answers (110) - Page 3
Now you don't need go anywhere to get the best interview questions on Microsoft technology. We are trying to gather all real interview questions asked from MNCs and put them here. You can also assist us in doing so by submitting .net interview questions. These questions are generally different from certification questions however it may help you in that too.

110 records found. 


@using(Html.Beginform())
 
{
 
Content Here.....
 
}
 
It ensures that an object is disposed when it goes out of scope.


Add stylesheet :
 

<link rel="StyleSheet" href="@Href(~Content/Site.css")" type="text/css"/>


It is a tool that provides flexible menus, breadcrumb trails, and SEO features for the .NET MVC framework, similar to the ASP.NET SiteMapProvider model.
 

You can download it as free through NuGet package for .NET MVC 2.0/3.0/4.0








Cross Site Request Forgery (CSRF) is a type of attack on the web application or on the website where a malicious user can insert or update data on behalf of the logged in user of the application by giving him a link that is not of the victim website but attackers own website.
 

In this type of attack the victim website user doesn't know that by clicking on malicious user link he is helping him to update malicious data into his website.
 

This generally happen by posting data on the victim website by a hidden form and submitting in using JavaScript or jQuery automatically.


To avoid Cross Site Request Forgery (CSRF) in ASP.NET MVC, you need to do two things.
 

1. Add
 [ValidateAntiForgeryTocken] attribute in the Controller Action method which is executing when the form data is being submitted. 

2. Add
 @Html.AntiForgeryTocken() element in the HTML form.


There are 6 different types of Scaffold templates in ASP.NET MVC that is used to create a view automatically based on the Model selected.
 

Empty: 
It creates an empty view and only model type is specified in the View page using @model
 

Create: 
It creates a view with a form that helps to create a new record for the model. It automatically generates a label and input field for each property in the Model.
 

Delete : 
It creates a view with the list of records from the Model collection along with Delete link to delete records.
 

Details: 
It creates a view that displays a lable and the value of each property of the Model.
 

Edit 
It creates a view with a form for editing existing model data. It also generates a form with label and field for each property of the Model.
 

List: 
It creates a view with html table that lists the model from the Model collection. It generates html table column for each property of the model. In general, it accepts IEnumerable<ModelType> and iterate through each item of the Enumerable collection. It automatically renders edit, delete links for each record of the Model collection in a column and Create link on the page that target to Create action.


In the default template of ASP.NET MVC, we get _ViewStart.cshtml page that is used to almost similar to MasterPage in ASP.NET Web Form or like a layout template.
 

The code of ViewStart executes before the actual view code executes. By default, _ViewStart template is applied to all view files of this or any sub directory under this directory.
 

The _ViewStart.cshtml file contains following code.
 


@{

Layout = "~/Views/Shared/_Layout.cshtml";

}

As this code runs before any view code so we have flexibility to specify a different Layout for a particular view.
 

Because this code runs before any view, a view can override the Layout property and choose a different
 
one.


To write dashed attribute of HTML element using ASP.NET MVC Helper methods, we replace "-" with "_" in the anonymous type parameter. eg.
 


@using (Html.BeginForm("Create", "Home", FormMethod.Post,

new { data_validatable=true }))


returns below output
 


<form action="/Home/Create" method="Post" data-validatable="true" >

Notice, the data-validate attribute of the form element.


The Html.ValidationSummary helper method is used to display all validation errors in the ModelState dictionary, either model property level or errors associated with ModelState.
 

Model Property level errors are errors that are set as an attributes of the property of the Model. eg 


[Required]

[StringLength(100, ErrorMessage="The Title must not be more than 100 characters long.")]

public string Title { get; set; }


In the above code, the Title field is a mandatory field and can only accept 100 characters.
 

The ModelState level errors are errors that are set by developer in the Controller by using below code snippet. 


ModelState.AddModelError("", "There is an error!");


In this case, the error will be displayed in place of Validation summary like this
 


<div class="validation-summary-errors">

<ul>

<li>There is an error!</li>

</ul>

</div>



The attribute in the Model field for the Identity column of the database should be DatabaseGenerated(System.ComponentModel.DataAnnotations.Schema.DatabaseGeneratedOption.Identity) like below
 



[Key]

[DatabaseGenerated(System.ComponentModel.DataAnnotations.Schema.DatabaseGeneratedOption.Identity)]

[Required]

public int CategoryId { get; set; }

Thanks





MVC is a framework pattern that splits an application logic into three different roles: Model, View and Controller.
 

Model: Business entity on which overall application operates.MVC does not specifically mention the Data access layer as it is encapsulated by the model. 

View: User interface that renders the model into a form of interaction. 

Controller: Handles the request from the view and updates the model resulting in a change in model's state. 

These are the three important classes(model, view and controller) required for MVC architecture.


The process of breaking a computer program into various features that overlap in functionality implies Separation of concerns.
 
MVC separates the content from presentation and data-processing from content.


For group of views that all use the same layout, this can get a bit redundant and harder to maintain.
 
The _ViewStart.cshtml page can be used to remove this redundancy. The code within this file
 
is executed before the code in any view placed in the same directory. This fi le is also recursively applied to any view within a subdirectory.
 
When we create a default ASP.NET MVC project, we find there is already a _ViewStart
 
.cshtml fi le in the Views directory. It specifi es a default layout:
 
@{
 
Layout = "~/Views/Shared/_Layout.cshtml";
 
}
 
Because this code runs before any view, a view can override the Layout property and choose a different one. If a set of views shares common settings, the _ViewStart.cshtml file is a useful place to consolidate these common view settings. If any view needs to override any of the common settings, the view can set those values to another value.


The controller gets the first hit and loads the model. Most of the time we would like to pass the model to the view for displaying data and so we use session variables, viewstate and so on. But the problem with using sessions or view state object is the scope. ASP.NET sessions have session scope and the view state have page scope. In MVC, we would like the data to be maintained when the hit comes to the controller and reaches the view and after that the scope of the data should expire.
 

That’s where the new session management technique has been introduced in the ASP.NET MVC framework, i.e., ViewData.


[HttpPost]
 
public ActionResult SaveResumeAsPdf(FormCollection fc)
 
{
 
if (Session["UserName"] != null)
 
{
 
BaseFont font = BaseFont.CreateFont(BaseFont.COURIER, BaseFont.CP1250, false);
 
PdfContentByte _pcb;
 
Document document = new Document();
 
try
 
{
 
PdfWriter writer = PdfWriter.GetInstance(document, new FileStream(Server.MapPath("~/Resumes/" + Session["UserName"] + ".pdf"), FileMode.Create));
 
document.Open();
 
_pcb = writer.DirectContent;
 
_pcb.BeginText();
 
_pcb.SetFontAndSize(font, 14);
 
int count = 30;
 
foreach (string item in fc.AllKeys)
 
{
 
_pcb.ShowTextAligned(PdfContentByte.ALIGN_LEFT, item, 50, 780 - count, 0);
 
_pcb.ShowTextAligned(PdfContentByte.ALIGN_LEFT, fc[item], 250, 780 - count, 0);
 
count = count + 30;
 
}
 
_pcb.EndText();
 
writer.Flush();
 
}
 
finally
 
{
 
document.Close();
 
}
 
}
 
}

Whenever you want to use two models in a single view, then add the models to the view in the following way,
 

@using MvcSampleCFA_02032014.Models;
 
@model Tuple<PersonCFA, AddressCFA>
 

Now, you can access all the properties present in the two models.


Repositories are minly used in MVC. It does not mean creating the database by itself or storing the data anywhere. It is just an approach in MVC. As we have n-tier architecture in asp.net, similarly repositories are a kind of architecture in MVC where we can create a repository class and write all the business logic in this class. We can just call this method from controller and there is no need to write any kind of business logic which makes our controller simple.
ASP.NET MVC Interview Questions and Answers (110) - Page 4
Now you don't need go anywhere to get the best interview questions on Microsoft technology. We are trying to gather all real interview questions asked from MNCs and put them here. You can also assist us in doing so by submitting .net interview questions. These questions are generally different from certification questions however it may help you in that too.



Normally, I would put most of general layout related css into content/style.css
 

If you use theme, then put it into content/theme/{themename}/style.css
 
If you create custom html control, i would try to create another css file for control and put it under content/control.css
 
In most of time, jquery is used in the asp.net MVC, so it make sense to put it's css in Script/jquery/{pluginName}/xxx.css
 
There could be more, but that's what's in my head now.
 

Splitting the css into multiple files is a good thing from a maintenace point of view. It makes it easier to work with and apply changes. However, multiple files can have an impact on application performance as the browser has to download each file individually. You can haev the best of both worlds though.
 

The technique that is recommended is to bundle all your html files for deployment so that it is served as 1 single file. The nice thing about this approach is that it lets you develop with multiple files, giving you ease of use. But get on the fly css file combination so that your browser only has to download one file.










ASP.NET MVC Interview Questions and Answers (110) - Page 5
Now you don't need go anywhere to get the best interview questions on Microsoft technology. We are trying to gather all real interview questions asked from MNCs and put them here. You can also assist us in doing so by submitting .net interview questions. These questions are generally different from certification questions however it may help you in that too.



ASP.NET MVC Interview Questions and Answers (110) - Page 6
Now you don't need go anywhere to get the best interview questions on Microsoft technology. We are trying to gather all real interview questions asked from MNCs and put them here. You can also assist us in doing so by submitting .net interview questions. These questions are generally different from certification questions however it may help you in that too.





Url.RouteUrl is used to generate a fully qualified URL for specified route values by using a route name configured in App_Start/RouteConfig.cs file. 


@Url.RouteUrl("MyCustomRoute", new { action = "New", id = 12, Name = "Sheo" })
gives output as /CustomController/New/12?Name=Sheo 


Url.HttpRouteUrl is also used to generate fully qualified URL for the specified route values but for Web API Routes. Internally this method add an "httproute" entry to routeValues. GetVirtualPath method of the Web Api route classes return null unless we include "httproute" in the values.
 

@Url.HttpRouteUrl("MyCustomRoute", new { action = "New", id = 12, Name = "Sheo" })</p>
gives output as /CustomController/New/12?Name=Sheo&httproute=True. 

Notice httproute query-string at the end.


Its not mandatory to be URL string must be in
 controller/action/params format. 

If User defined in his
 RouteConfig file like {controller}/{action}/{id} Query string will be controller/action/id. 

if user defined in his
 RouteConfig file like {action}/{controller}/{id} Query string will be 
Action/controlleer/id.


Html.EditorFor


@Html.EditorFor(model => model.LastName)

This HTML helper method is very dynamic in nature. Based on which type of data is passed to this method, the output changes.
 

For example,
 
1. if model property type is of string type, it renders a textbox
 
2. if the property type is boolean type it renders a checkbox.
 
3. if the property type is of integer type, it render input type="number" textbox.
 

In order to control the output of the Html.EditorFor we can use EditorTemplates for different data types.
 

Html.TextBoxFor


@Html.TextBoxFor(model => model.LastName)

This HTML helper method only renders a TextBox as output irrespective of whatever data type the model property is of.


No,we do not have ViewState concept in Asp.Net MVC that is used for storing or persisting the values of controls in the current page.
 
So,Asp.Net MVC pages are very Lightweighted and our request and response times becomes much faster.

1. For retaining the values during postback in the MVC page values we can use Ajax,so that values in the control will never be clear. 
2. For temporarily storing the value in current and the subsequent requests,we can use TempData concept.


Angular Tutorial (Update to Angular 7)

As Angular 7 has just been released a few days ago. This tutorial is updated to show you how to create an Angular 7 project and the new fe...