Transcript Document

ASP.NET and
Model View Control
Jesper Tørresø
ITNET2
F08
Turns around the usual way
• A MVC Controller takes control over from the standard
ASP.NET Framework View Engine.
• From Scott Guthrie
– ”The MVC framework supports using the existing ASP.NET
.ASPX, .ASCX, and .Master markup files as "view templates"
(meaning you can easily use existing ASP.NET features like
nested master pages, <%= %> snippets, declarative server
controls, templates, data-binding, localization, etc). It does
not, however, use the existing post-back model for
interactions back to the server. Instead, you'll route all enduser interactions to a Controller class instead - which helps
ensure clean separation of concerns and testability (it also
means no viewstate or page lifecycle with MVC
based views). ”
But what about the existing
ASP.NET framework?
• May we ”only” use HTML control and not
server controls and/oe user controls?
• All HTML from controls may be used
• We can use the already known APS.NET
server controls and also a special MVC
User Control. (!!!!)
• But we must take care of routing etc by
our self.
Model View Control
JSP Model 1 architecture (from 1998-1999)
Is this original ASP.NET ?
Model View Control
JSP Model 2 architecture
Model, View and Controller:
The pattern MVC, which stands for Model-View-Controller, separates
an application in three components:
• Model: this is where all the business logic of the application resides:
it can range from a simple static class that returns a dataset to a
complex multi-assembly Business Logic Layer that uses an
assembly specific to the Data Access Layer.
• View: at the other end of the application is the View, which displays
the application's user interface and contains the representation of
the data that have been retrieved by the Model. This doesn't have
logic, other than the one strictly related to the presentation of data.
• Controller: between the two components stands the Controller. It
acts as the orchestrator of all the interactions among the other
components and the users: it handles the requests, reads the form
values, passes them to the Model, decides which View to render
and finally sends the data to be rendered to the View.
Interaction
1. The request comes from the client
and hits the Controller.
2. The Controller calls the Model in
order to perform some "business"
operations.
3. The Model returns the results of the
operations back to the Controller.
4. The Controller decides which View
needs to be rendered and sends it
the data that must be rendered.
5. Finally the View renders the output
and sends the response back to the
client.
Model 2 and ASP.NET
URL Routning
• Normal ASP.NET
– http://server/application/Products.aspx?id=4
• ASP.NET MVC
– http://server/application/Products/show/beverages
• The URL’s are interpreted by a
RouteHandler and known as routes to the
Controller.
URL Routning 1
• The URL patterns defined are called
routes Ex:
Valid route definitions
Examples of matching URL
{controller}/{action}/{id}
/Products/show/beverages
{table}/Details.aspx
/Products/Details.aspx
blog/{action}/{entry}
/blog/show/123
{reporttype}/{year}/{month}/{day} /sales/2008/1/5
Typically, you add routes in the handler for the
Application_Start event in the Global.asax file. This approach
makes sure that the routes are available when the application
starts.
URL Routning 2
• Initiating application in Global.asax.cs
void Application_Start(object sender, EventArgs e)
{
RegisterRoutes(RouteTable.Routes);
}
public static void RegisterRoutes(RouteCollection routes)
{
routes.Add(new Route ( "Category/{action}/{categoryName}"
new CategoryRouteHandler() )
{
Defaults = new RouteValueDictionary
{{"categoryName", "food"}, {"action", "show"}}
}
);
}
URL Routning 3
• See more here
– http://quickstarts.asp.net/3-5extensions/mvc/URLRouting.aspx
• Setting default values in Routes
• Adding constraints Routes
• Making a MVC route to a URL
Sow! What is ASP.NET MVC?
• ASP.NET MVC is a framework that allows developers to apply the
MVC pattern in the development of an ASP.NET application, thus
allowing a better separation of concerns, which results in better
reusability and easier testing.
• MVC was one of the concepts originally found in SmallTalk. MVC
and the web seem like a match made in heaven and allow for a
simple way of building complex web applications.
• To understand why this recently re-discovered way of building web
application was developed, we need to have a look at the pitfalls of
the standard model, which is the web-form approach.
– First, it is event based: it can be good or bad depending on how you
look at it. Good because it helps VB6 and WinForms developers to
smoothly migrate their skills to the web application development. Bad
because there are dozens of events that are raised during the page lifecycle, and it's not trivial to understand where to put your code. Also
because the process logic is tightly coupled with the page lifecycle, it is difficult to test using automated tests. Cont..
Sow! What is ASP.NET MVC? cont.
– It also uses server forms and ViewState: again, as with the event based
model, it can be good since this hides to the developer all the problems related
to maintaining the state of the page (values of textboxes, contents of dropdowns
and so on), but can also be bad if you want to control exactly how the page is
rendered, and you don't need to maintain all the state.
– Furthermore, it uses server controls: good because they render the HTML for
you; bad since they render it the way they want.
•
•
With the MVC framework you gain back the control of the order in which
things happen during the page life-cycle, of the way state is persisted
between requests, and the code with which HTML is rendered. And thanks
to a better separation of concerns it's easier to test the process logic. But
all this control has a cost: you have to do everything by yourself.
Keep in mind this: the MVC framework is not a replacement for the webform programming model, but it's an alternative programming model, for
those who want to have a better control and want to be able to also test the
presentation logic