Book Review - ASP.NET 3.5 Application Architecture and Design

3.9 (10 votes)

Back in the day, when I began to get interested in ASP.NET application architecture and design, I spent hours hunting for a book that would explain all I needed to know.  I wanted one that focused on ASP.NET, with its special demands, rather than a general .NET development book.  I wanted a book that would explain what layers and tiers were, and how I should separate code out to make it more scalable and reusable.  I wanted a book that would explain how I could take my skills to the next level. I couldn't find one.  There was a big gap in the market.  Vivek Thakur has attempted to fill this gap, with this apty named title: ASP.NET 3.5 Application Architecture and Design.

ASP.NET 3.5 Application Architecture and Design

The book is aimed at beginners and intermediate ASP.NET developers primarily.  Vivek claims in his preamble that experienced developers would also benefit from reading the book.  It is intended to provide an understanding of architecture and design in a practical way, rather than a theoretical one.  The first chapter looks at the difference between tiers and layers, and explains what you get from ASP.NET out of the box.  There is also an interesting, but brief look at project management.  The second chapter looks at the code-behind model in a lot more detail, before dismissing it as suitable only for a simple Guestbook application.  Chapters 3 and 4 look at layers, tiers and spend a bit of time introducing UML, before Chapter 5 looks at ASP.NET MVC.  Design Patterns are the focus of Chapter 6.  Chapter 7 covers Service Oriented Architecture and WCF, followed by Database design in Chapter 8.  Chapter 9 wraps the book up within 250 pages, with a rather unconvincingly tacked-on look at Localisation.

Now, I could have ended my review of this book here.  If I had, you would probably feel the same way as I did when I finished the book - less than satisfied.  One of the main problems with this book is that it simply isn't long enough.  It has the feel of a series of blog posts that have been published over a period, where the author needs to remind the reader of what was said in previous posts made some weeks or months ago.  For a short-ish book, there is a lot of repetition.  And the repetition doesn't make up for the lack of substance.

Vivek introduces a number of concepts, and I am sure that developers who want to learn the basics of structuring an ASP.NET application will get a fair amount out of this book, but it would have been better entitled "Beginning ASP.NET 3.5 Application and Architecture".  It's the lack of deep-diving that prevents this book from becoming a "Bible".  Actually, it's more than that.  The code samples are poorly formatted (although that could be taken care of in a trice if the book is ever reprinted), but the language doesn't flow that well.

Vivek does a good job in explaining how to layer code so that it is more maintainable, reusable, scalable etc.  But he falls into the same cliche that all others who write about architecture seem to. He talks about there being ultimately two kinds of web project - enterprise applications and guestbook sites.  No one discusses the middle ground, which probably accounts for 70% of development.  He doesn't really explain what the tipping points are that should make a developer consider one architectural approach over another.  It's an all-or-nothing kind of thing.

For a book that is aimed at taking developers from the code-behind approach to a higher level, there are serious (in my view) omissions.  Testing is brushed up against in a few places, but I would like to have seen this warrant a separate chapter.  I would like to have the various testing tools explained as well as how to use one or two of them.  I would like to have seen some discussion over the various approaches to larger scale development, such as TDD etc.  There are a lot of other tools available to aid in larger scale development, such as Inversion of Control containers, source control packages, and most obvious of all, Object Relational Mappers.  I was disappointed that none of these were even mentioned.  Even as a beginner, I would love to have known what all these were and whether I should be using them.

If this book had been clearly labelled as a beginners guide, I would probably give it 3.5 out of 5, with the caveat that you would need to pick up other references to provide a full introduction.  If the publishers are serious that the book should be useful to developers who have already moved beyond the SqlDataSource control, I'd givethat claim 0 out of 5.

One final thing.  This is the first Packt book I have ever picked up.  It won't necessarily be the last, but the next book may be if it is as poorly edited as this one.

You might also like...

Date Posted:
Last Updated:
Posted by:
Total Views to date: 36599


- Alan

I agree with what you said about this being a beginners book. I wasn't too impressed either. And the code formatting was terrible.

- naveenj

I also felt the same...
Expected a lot more from a guy of Viveks caliber

- Phrasal verb lesson

Thanks for taking the time to discuss this, I feel strongly about it and love learning more on this topic. If possible, as you gain expertise, would you mind updating your blog with more information? It is extremely helpful for me._

Recent Comments

dave 20/08/2016 14:57
In response to ASP.NET Web Pages vNext or Razor Pages
Do SimplemembershipProvider in viewpages is supported?...

Steven 18/08/2016 04:40
In response to Entity Framework Code First and Stored Procedures
Can you provide the directives (using statements) you're using for EF7 example?...

yousaid 17/08/2016 22:08
In response to ASP.NET Web Pages vNext or Razor Pages
Increasingly, learning a Microsoft tool is no longer worth the return on investment. Too many tools...

jared 12/08/2016 05:54
In response to ASP.NET Web Pages vNext or Razor Pages
hi mike, just for clarification, is viewpages something different from webpages? is webpages still...

Jocke 08/08/2016 20:37
In response to Loading ASP.NET Core MVC Views From A Database Or Other Location
Good post! If this was to be implemented in a CMS where users can change the view files, how would I...

cyrus 05/08/2016 19:49
In response to ASP.NET Web Pages vNext or Razor Pages
I think adding these features to webpages make it complicated. msft forget webpages goal so we move...

Curt Smith 27/07/2016 20:38
In response to ASP.NET Web Pages vNext or Razor Pages
I am only slightly disappointed to hear that WebMatrix is officially dead, because I suspected this...

Darshan Raj L G 27/07/2016 13:20
In response to Implementing SQL Server Full-Text Search In An ASP.NET MVC Web Application With Entity Framework
I though it would be more helpful for somebody who wants to work with Entity Framework... please EF...

Satyabrata 25/07/2016 08:09
In response to Loading ASP.NET Core MVC Views From A Database Or Other Location
Very Interesting!!...

Jerrie Pelser 23/07/2016 05:08
In response to Loading ASP.NET Core MVC Views From A Database Or Other Location
Very cool concept Mike!...