four questions in the attached file
please check the book in PDF file
Pg. 04 |
Question Four |
Deadline: Saturday 21/03/2020@ 23:59
[Total Mark for this Assignment is 5]
E-Portals Development
IT405
College of Computing and Informatics
Question One
1.5 Mark
Learning Outcome(s):
Evaluate the effectiveness of portals.
Content proxy is a web service on your server that can fetch data from external URLs and return it to the browser. How does the proxy improve the load time for users?
Question Two
1.5 Marks
Learning Outcome(s):
Recognize the main elements of portals development.
What are the advantages and disadvantages of using HTTP POST for web service calls?
Question Three
1 Mark
Learning Outcome(s):
Recognize the main elements of portals development.
What is the full form of LINQ? Explain LINQ to SQL.
Question Four
1 Mark
Learning Outcome(s):
Evaluate the effectiveness of portals
What are the advantages of combining multiple Ajax calls into one call? Write any TWO.
www.free-ebooks-download.org
www.free-ebooks-download.org
Praise for Building a Web 2.0 Portal with ASP.NET 3.5
“Omar and his collaborators have applied their awesome talents and a huge amount of time
to crafting what might be the most advanced web site yet that’s based on ASP.NET and
Ajax. In this book, Omar distills everything he’s learned from his experience, going in-
depth into design goals, architecture, and implementation, including many pitfalls that he
teaches you how to avoid. If you’re serious about creating a high-performance, modern,
Ajax-based ASP.NET web site, Building a Web 2.0 Portal with ASP.NET 3.5 is for you.”
— Mike Pope, Microsoft User Education, Microsoft Corporation
“An outstanding overview of the technologies, techniques, and best practices involved in
working with today’s most popular web application model. Highly recommended for any
web developer who wants to stay relevant.”
— Craig Wills, Training Manager, Infusion
Building a Web 2.0 Portal
with ASP.NET 3.5
Other Microsoft .NET resources from O’Reilly
Related titles C# 3.0 Cookbook™
C# 3.0 Design Patterns
C# 3.0 in a Nutshell
Learning ASP.NET 2.0 with
AJAX
Programming ASP.NET
Programming ASP.NET AJAX
Programming C# 3.0
Programming .NET 3.5
.NET Books
Resource Center
dotnet.oreilly.com is a complete catalog of O’Reilly’s books on
.NET and related technologies, including sample chapters and
code examples.
ONDotnet.com provides independent coverage of fundamental,
interoperable, and emerging Microsoft .NET programming and
web services technologies.
Conferences O’Reilly brings diverse innovators together to nurture the ideas
that spark revolutionary industries. We specialize in docu-
menting the latest tools and systems, translating the
innovator’s knowledge into useful skills for those in the
trenches. Visit conferences.oreilly.com for our upcoming
events.
Safari Bookshelf (safari.oreilly.com) is the premier online refer-
ence library for programmers and IT professionals. Conduct
searches across more than 1,000 books. Subscribers can zero in
on answers to time-critical questions in a matter of seconds.
Read the books on your Bookshelf from cover to cover or sim-
ply flip to the page you need. Try it today for free.
Building a Web 2.0 Portal
with ASP.NET 3.5
Omar AL Zabir
Beijing • Cambridge • Farnham • Köln • Paris • Sebastopol • Taipei • Tokyo
Building a Web 2.0 Portal with ASP.NET 3.5
by Omar AL Zabir
Copyright © 2008 Omar AL Zabir. All rights reserved.
Printed in the United States of America.
Published by O’Reilly Media, Inc., 1005 Gravenstein Highway North, Sebastopol, CA 95472.
O’Reilly books may be purchased for educational, business, or sales promotional use. Online editions
are also available for most titles (safari.oreilly.com). For more information, contact our
corporate/institutional sales department: (800) 998-9938 or corporate@oreilly.com.
Editor: John Osborn
Production Editor: Laurel R.T. Ruma
Copyeditor: Laurel R.T. Ruma
Proofreader: Mary Brady
Indexer: John Bickelhaupt
Cover Designer: Karen Montgomery
Interior Designer: David Futato
Illustrators: Robert Romano and Lesley Borash
Printing History:
December 2007: First Edition.
Nutshell Handbook, the Nutshell Handbook logo, and the O’Reilly logo are registered trademarks of
O’Reilly Media, Inc. Building a Web 2.0 Portal with ASP.NET 3.5, the image of a giant green sea
anemone, and related trade dress are trademarks of O’Reilly Media, Inc.
Microsoft, MSDN, the .NET logo, Visual Basic, Visual C++, Visual Studio, and Windows are registered
trademarks of Microsoft Corporation.
Many of the designations used by manufacturers and sellers to distinguish their products are claimed as
trademarks. Where those designations appear in this book, and O’Reilly Media, Inc. was aware of a
trademark claim, the designations have been printed in caps or initial caps.
While every precaution has been taken in the preparation of this book, the publisher and author assume
no responsibility for errors or omissions, or for damages resulting from the use of the information
contained herein.
This book uses RepKover™, a durable and flexible lay-flat binding.
ISBN-10: 0-596-51050-0
ISBN-13: 978-0-596-51050-3
[C]
http://safari.oreilly.com
mailto:corporate@oreilly.com
vii
Table of Contents
Preface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi
1. Introducing Web Portals and Dropthings.com . . . . . . . . . . . . . . . . . . . . . . . . . . 1
Defining a Web Portal 2
Defining a Web 2.0 Portal 4
Using a Web Portal 4
Navigating Dropthings 5
Using ASP.NET AJAX 8
Using C# 3.0 and .NET 3.5 9
Summary 10
2. Architecting the Web Portal and Widgets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Using a Widget Framework 20
Adding Widgets 26
Maximizing the First-Visit Experience 28
Rendering a Second-Visit Experience 30
Improving ASP.NET AJAX Performance 31
Adding Authentication and Authorization 36
Preventing Denial-of-Service Attacks 38
Summary 40
3. Building the Web Layer Using ASP.NET AJAX . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Implementing the Start Page of a Web Portal 41
Building a Custom Drag-and-Drop Extender for a Multicolumn Drop Zone 60
Implementing WidgetContainer 74
Building Widgets 81
Page Switching: Simulating a Nonpostback Experience 92
viii | Table of Contents
Using the Profile Object Inside a Web Service 94
Implementing Authentication and Authorization 95
Implementing Logout 98
Summary 100
4. Building the Data and Business Layers Using .NET 3.5 . . . . . . . . . . . . . . . . . 101
Introducing LINQ to SQL 101
Building the Data Access Layer Using LINQ to SQL 104
Introducing Windows Workflow Foundation 112
Building the Business Layer Using WF 113
Implementing the DashboardFacade 127
Summary 133
5. Building Client-Side Widgets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 134
Delaying Server-Side Widget Loading 135
Content Proxy 138
Building a Client-Side RSS Widget 142
Building a Client-Side Flickr Widget 146
Summary 151
6. Optimizing ASP.NET AJAX . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152
Combining Multiple Ajax Calls into One Call 152
Timing and Ordering Ajax Calls to the Server 154
Using HTTP GET Calls Instead of HTTP POST 165
Working with the this Function 166
Summary 168
7. Creating Asynchronous, Transactional, Cache-Friendly Web Services . . . . 169
Scalability Challenges with Web Services 169
Asynchronous Web Methods 171
Modifying the ASP.NET AJAX Framework to Handle Web Service Calls 175
Developing Your Own Web Service Handler 177
Making an Asynchronous and Cache-Friendly Proxy 189
Scaling and Securing the Content Proxy 191
Summary 196
Table of Contents | ix
8. Improving Server-Side Performance and Scalability . . . . . . . . . . . . . . . . . . . 197
Instrumenting Your Code to Identify Performance Problems 198
Optimizing the HTTP Pipeline 199
Optimizing ASP.NET 2.0/3.5 Before Going Live 200
Optimizing Queries in the ASP.NET Membership Tables 201
Optimizing the ASP.NET 2.0/3.5 Profile Provider Before You Go Live 203
ASP.NET Production Challenges 219
Redirecting Traffic from an Old Web Site to a New One 221
Summary 223
9. Improving Client-Side Performance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224
Understanding Web Caching 224
Content Delivery Networks 234
Optimizing Internet Explorer JavaScript Performance 238
Reducing the Web Service Call Payload 246
Loading the UI on Demand 247
Using Read-Ahead Caching for Ajax Calls 250
Hiding HTML Inside
xi
Preface1
Web 2.0 Ajax portals are among the most successful web applications of the Web
2.0 generation. iGoogle and Pageflakes are the pioneers in this market and were
among the first to show Ajax’s potential. Portal sites give users a personal homepage
with one-stop access to information and entertainment from all over the Web, as
well as dashboards that deliver powerful content aggregation for enterprises. A Web
2.0 portal can be used as a content repository just like a SharePoint or DotNetNuke
site. Because they draw on Ajax to deliver rich, client-side interactivity, Web 2.0 por-
tals improve usability and provide faster performance compared to non-Ajax web
sites. Also, because portals are commonly composed of widgets (small plug-and-play
type applications), there’s no limit to how much functionality you can provide, sim-
ply by adding more and more widgets. Their use also keeps the core architecture of
the portal clean and simple because widgets are developed and maintained indepen-
dently. DotNetNuke is a great example of a widget-powered portal concept that has
created a new era in highly decoupled enterprise web applications.
This book takes a fresh new look at portal solutions using the latest cutting-edge
technologies from Microsoft. In developing personal, educational, community, and
enterprise portals, I have had to deal with many interesting design, development,
scalability, performance, and production challenges. In this book, I have tried to
show solutions to some of these challenges by building an open source Web 2.0 Por-
tal prototype, and then walk you through through the design and architectural chal-
lenges, advanced Ajax concepts, performance optimization techniques, and server-
side scalability challenges involved. The prototype also shows you practical imple-
mentation of the cutting-edge .NET 3.0 and 3.5 frameworks, including LINQ and the
Windows Workflow Foundation. Moreover, it explores Ajax web site details, browser
performance and compatibility challenges, security challenges, and ASP.NET AJAX
framework advantages and shortcomings.
xii | Preface
The project is available at www.dropthings.com. Dropthings is an open source exam-
ple of what can be done with the new technologies from Microsoft. It is intended for
educational purposes only. Although it does come close to real web portal (like Page-
flakes) in terms of its feature set, performance, security, and scalability, it does a
good job of showing you how to put together several new technologies in a working
web application.
Who This Book Is for
This book is primarily for ASP.NET 2.0 or 3.5 developers who have already devel-
oped one or more web applications and have a good grip on JavaScript and ASP.NET
2.0. The reader is also expected to have basic understanding of ASP.NET AJAX. This
information is available in numerous publications, including several from O’Reilly
that are listed in the Roadmap page for this book.
Intermediate developers, looking for ways to gain insight into web development chal-
lenges and learn how a successful production web site is built and run, will greatly
benefit from this book. Advanced developers will learn how to build a rock solid web
application that can withstand millions of hits every day around the clock, survive
sudden scalability demands, prevent hack attempts and denial of service attacks,
deploy and run a web site on a distributed cluster environment utilizing Content
Delivery Networks (CDN), face real-life production challenges, and much more.
How This Book Is Organized
This book first describes what an Ajax web portal (aka a Web 2.0 portal) is and
how it can be useful as a model for personal web sites, corporate intranets, or a
mass consumer web application. Then it walks you through the architectural chal-
lenges of such an application and provides a step-by-step guide to solving design
issues. It explains what a widget is and how widget architecture can create a highly
decoupled web application that allows the addition of an infinite number of fea-
tures to a web site.
It following chapters, you’ll find step-by-step guides for developing several compo-
nents of the web project using ASP.NET 2.0/3.5 and ASP.NET AJAX 1.0, the busi-
ness layer in Workflow Foundation, and the data access layer using LINQ to SQL.
Once the basic foundation is up, it goes deep into difficult challenges like first-time
visit performance, browser compatibility and memory leaks, advanced caching tech-
niques, putting too much content and functionality on a single page and so on. It
then goes into some real-life Ajax and ASP.NET 2.0/3.5 challenges that I have solved
in building high-volume commercial portals.
http://www.dropthings.com
Preface | xiii
I have also sprinkled a number of real-life war stories throughout the book that high-
light some of the real-life problems I have encountered in building portals like
Dropthings. You’ll find them, not surprisingly, wherever you encounter the heading,
“Real-Life.”
Finally, it presents some hard-to-solve scalability and security challenges of Ajax por-
tals and 13 production disasters that are common to web applications that reach mil-
lions of users all over the world.
Here’s a chapter-by-chapter summary:
Chapter 1, Introducing Web Portals and Dropthings.com
Introduces you to the attributes of a web portal and to the applications that you
will learn to build throughout the book. Chapter 1 also shows you how ASP.NET
AJAX and .NET 3.5 are used in the product.
Chapter 2, Architecting the Web Portal and Widgets
Gives you an architectural overview of Dropthings.com. It also explains the wid-
get architecture and how to build highly decoupled web applications using wid-
gets. It touches on some performance and security challenges of Ajax web sites.
Chapter 3, Building the Web Layer Using ASP.NET AJAX
Gives a detailed explanation on how the web application is built, starting from the
homepage and the widgets. It shows how the drag-and-drop functionality is pro-
vided using ASP.NET AJAX 1.0, how a real widget is built, and how ASP.NET 3.5
is used to build the server-side part of the web layer.
Chapter 4, Building the Data and Business Layers Using .NET 3.5
Shows how LINQ is used to build the data access later and .NET 3.0 is used to
build the business layer by extensively using Workflow Foundation.
Chapter 5, Building Client-Side Widgets
Shows how to build widgets using JavaScript for faster performance and better
caching. It shows how a content bridge or proxy service is built that allows wid-
gets to fetch content from external sources.
Chapter 6, Optimizing ASP.NET AJAX
Goes deep into Ajax-enabled principles for making sites faster, more cache
friendly, and scalable. It talks about browser specific challenges and many
under-the-hood techniques to get maximum performance out of the Ajax
framework.
Chapter 7, Creating Asynchronous, Transactional, Cache-Friendly Web Services
Shows you how to build a custom web service call handler for Ajax calls in order
to overcome some shortcomings in ASP.NET AJAX 1.0 and enable your web ser-
vices to become asynchronous, transactional, and more cache-friendly. It also
talks about scalability and security challenges of web applications that rely
heavily on web services.
xiv | Preface
Chapter 8, Improving Server-Side Performance and Scalability
An ASP.NET 2.0 web application has many scalability and performance surprises
as it grows from a hundred-user to a million-user web site. Learn how to solve per-
formance, reliability, and scalability challenges of a high volume web site.
Chapter 9, Improving Client-Side Performance
Ajax web sites provide a lot of functionality on the client-side browser that intro-
duces many browser specific challenges and JavaScript performance problems.
This chapter provides many tips and tricks for overcoming speed and memory
problems on the browser and making the UI load faster and be more responsive.
Chapter 10, Solving Common Deployment, Hosting, and Production Challenges
Last step of a web project development is to successfully deploy the product and
run it 24×7. Learn what it takes to deploy and run a high volume production
web site solving software, hardware, hosting, and internet infrastructure prob-
lems that can bring down your web site and cause great harm to your business.
What You Need to Use this Book
You need Visual Studio 2008 Professional Edition and SQL Server 2005 Developer
Edition. You can download the latest source code of the open source project from
www.codeplex.com/dropthings and set it up locally.
The open source project running at Dropthings will greatly benefit from your contri-
bution. You are welcome to participate in its development by extending the core
framework or building new widgets for the project.
Conventions Used in This Book
The following typographical conventions are used in this book:
Plain text
Indicates menu titles, menu options, menu buttons, and keyboard accelerators
(such as Alt and Ctrl).
Italic
Indicates new terms, URLs, email addresses, filenames, file extensions, path-
names, directories, and Unix utilities.
Constant width
Indicates commands, options, switches, variables, attributes, keys, functions,
types, classes, namespaces, methods, modules, properties, parameters, values,
objects, events, event handlers, XML tags, HTML tags, macros, the contents of
files, or the output from commands.
Constant width bold
Shows commands or other text that should be typed literally by the user.
http://www.dropthings.com
Preface | xv
Constant width italic
Shows text that should be replaced with user-supplied values.
This icon signifies a tip, suggestion, or general note.
This icon indicates a warning or caution.
Using Code Examples
This book is here to help you get your job done. In general, you may use the code in
this book in your programs and documentation. You do not need to contact us for
permission unless you’re reproducing a significant portion of the code. For example,
writing a program that uses several chunks of code from this book does not require
permission. Selling or distributing a CD-ROM of examples from O’Reilly books does
require permission. Answering a question by citing this book and quoting example
code does not require permission. Incorporating a significant amount of example
code from this book into your product’s documentation does require permission.
We appreciate, but do not require, attribution. An attribution usually includes the
title, author, publisher, and ISBN. For example: “Building a Web 2.0 Portal with ASP.
NET 3.5, by Omar AL Zabir. Copyright 2008 Omar AL Zabir, 978-0-596-51050-3.”
If you feel your use of code examples falls outside fair use or the permission given
above, feel free to contact us at permissions@oreilly.com.
Safari® Books Online
When you see a Safari® Books Online icon on the cover of your
favorite technology book, that means the book is available online
through the O’Reilly Network Safari Bookshelf.
Safari offers a solution that’s better than e-books. It’s a virtual library that lets you
easily search thousands of top tech books, cut and paste code samples, download
chapters, and find quick answers when you need the most accurate, current informa-
tion. Try it for free at http://safari.oreilly.com.
mailto:permissions@oreilly.com
http://safari.oreilly.com
xvi | Preface
How to Contact Us
Please address comments and questions concerning this book to the publisher:
O’Reilly Media, Inc.
1005 Gravenstein Highway North
Sebastopol, CA 95472
800-998-9938 (in the United States or Canada)
707-829-0515 (international or local)
707-829-0104 (fax)
There is a web page for this book, where we list errata, examples, and any additional
information. You can access this page at:
http://www.oreilly.com/catalog/9780596510503
To comment or ask technical questions about this book, send email to:
bookquestions@oreilly.com
For more information about our books, conferences, Resource Centers, and the
O’Reilly Network, see our web site at:
http://www.oreilly.com
The author of this book and Dropthings project can be reached at:
omar.zabir@mvps.org
The code for this book can be found here:
www.codeplex.com/dropthings
Acknowledgments
My deepest respect and appreciation to my parents for their support in writing this
book. Special thanks to Mike Pope at Microsoft and Craig Wills at Infusion for their
sincere support, ideas, and thorough reviews.
http://www.oreilly.com/catalog/9780596510503
mailto:bookquestions@oreilly.com
http://www.oreilly.com
mailto:omar.zabir@mvps.org
http://www.dropthings.com
1
Chapter 1 CHAPTER 1
Introducing Web Portals
and Dropthings.com1
In this book, I will show you how to develop an Ajax-enabled Web 2.0-style portal.
The portal is built using ASP.NET 3.5, ASP.NET AJAX, and .NET 3.5, as well as
Language-Integrated Query (LINQ) and SQL Server 2005. While building this appli-
cation, you’ll learn about the:
• Design decisions that must be made for and usability issues involved in a Web
2.0 user interface
• Architectural complexities and development challenges of JavaScript-rich, widget-
enabled web sites
• Production and maintenance challenges of running a high-volume web application
Ajax web portals are among the most extreme implementations of client-side tech-
nologies you’ll find on the Web. They not only use large amounts of JavaScript, CSS,
and HTML, but also push the Ajax and server-side technologies to their limits for
interactivity, performance, and scalability. By the time you finish reading this book,
you will be equipped with enough technical know-how to launch a Web 2.0 Internet
startup on your own.
The application example, which I have named Dropthings, for reasons that will
become clear shortly, is a reduced feature set prototype of a real web portal, like Goo-
gle’s iGoogle or Pageflakes. You will be able to deploy the Dropthings on a produc-
tion server and run it as your own personal web site, a group site, or even as a
corporate intranet. Including drag-and-drop enabled widgets, complete support for
personalization, the ability to place widgets on multiple pages, centralized authentica-
tion and authorization, and much more.
As you work through this book, you will see how Dropthings is architected and imple-
mented. It’s a real, living, breathing, open source web portal that you’ll find at http://
www.dropthings.com. Although the application does not compare to a real web portal
in terms of its code quality, feature set, scalability, performance, and other aspects of
the product, it works as a good proof of concept for several nascent technologies.
http://www.dropthings.com
http://www.dropthings.com
2 | Chapter 1: Introducing Web Portals and Dropthings.com
However, you can use it for your current day-to-day personal use, and you are wel-
come to support continued development of the project by adding more features to it
or by making cool new widgets for it.
The open source project for Dropthings is hosted at http://www.
codeplex.com/dropthings. Anyone can contribute.
Figure 1-1 shows the Dropthings site, which you will learn how to build in this book.
Defining a Web Portal
A web portal is a page that allows a user to customize his homepage by dragging and
dropping widgets onto it. This approach gives the user complete control over what
content he sees on his home page, where on the page he wants to see it, and how he
wants to interact with it.
A widget is a discrete piece on a web page that performs a particular function and
comes with its own UI and set of features. Examples of widgets include to-do lists,
address books, contact lists, RSS feeds, clocks, calendars, playlists, stock tickers,
weather reports, traffic reports, dictionaries, games, or almost anything you can
imagine that can be packaged up and dropped onto a web page. In a corporate envi-
ronment, widgets can connect to internal systems; for example, an expense tracker
widget can interact directly with the internal accounting system. If you are familiar
Figure 1-1. The Dropthings site is a widget-enabled Web 2.0 portal; you’ll build one like it using
ASP.NET 3.5, ASP.NET AJAX, the .NET Framework 3.5, and SQL Server 2005
http://www.codeplex.com/dropthings
http://www.codeplex.com/dropthings
Defining a Web Portal | 3
with the SharePoint Portal, then you already know about widgets, which are called
Web Parts in SharePoint and ASP.NET 2.0.
Specifically, an Ajax-powered web portal is a web portal that uses Ajax technologies
to create richer experiences for its users. It is one step ahead of the previous genera-
tion of web portals, including pioneer sites such as MSN or AOL, because it gives
you a state-of-the-art UI that behaves more like a Windows client application with
widgets, animations, pop ups, client-side data grids, and other effects not usually
found on a non-Ajax web portal. Not surprisingly, MSN and AOL have already
adopted many of the practices discussed in this book.
Some of the most popular Ajax web portals include iGoogle (www.google.com/ig),
My Yahoo (http://my.yahoo.com), and Pageflakes (www.pageflakes.com; see
Figure 1-2).
A web portal, especially one that is Ajax-powered, gives users a fun way to browse
the Internet. Users can add photos, videos, music, podcasts, and video blogs to their
Start page. The web portal can also help users become more productive by allowing
them to check email, read news, and get weather reports from a single page. They
can organize their digital life by putting appointment calendars, to-do-lists, and
address books in a central place on the Web. No matter where they happen to be—
in the office, home or airport—as long as they can get to the Web, users can access
this information directly from their web portal. It’s like bringing the whole Internet
onto a single page, displayed exactly the way you want it to be. Gone are the days of
running after content—now information and entertainment comes to you.
Figure 1-2. Pageflakes uses widgets to deliver functionality, including local weather, local news,
videos, local photos, podcasts, stock portfolio, local events with Google Maps, and more
http://www.google.com/ig
my.yahoo.com
http://www.pageflakes.com
4 | Chapter 1: Introducing Web Portals and Dropthings.com
Defining a Web 2.0 Portal
The term “Web 2.0” defines a set of principles and practices for web applications,
which, when followed, entitle a web application to wear the Web 2.0 crown. A web
site can claim to be a Web 2.0 site if it:
• Allows users to control data presented on the web site
• Presents a platform that enables the mixing (or mash-up) of technologies and data
• Enables services to be consumed that are beyond the boundary of the application
• Harnesses collective intelligence by enabling the following:
— Aggregation of relevant content from heterogeneous sources
— User contributed content
— User moderation of content via tagging and rating
• Uses state-of-the-art technologies that take interactivity on the Web to the next
level by use of popular technologies like Ajax, Flash, and Silverlight.
Dropthings, being a web portal, allows a user to control what the user wants to put
on the page. The widget architecture allows mashup of technologies in the form of
widgets. It exposes web services that external entities can consume. The portal
aggregates content from many different sources, such as photos from Flickr, news
from CNN, weather reports from Weather.com, and many more. It supports user-
submitted content aggregation in the form of RSS feeds. Finally, it pushes inter-
activity on the Web to the next level by using Ajax technologies.
Using a Web Portal
With a web portal, every visitor to your web site will be able to customize and set it
up exactly the way they would like to see it the next time they visit. Best of all, the
layout is saved per user, so your master layout remains unchanged. Moreover, visi-
tors can add more widgets from a widget catalog and decorate the page as they like.
How an Ajax-Powered Start Page Is Different
The advantages of Ajax and a rich client-side experience give users a fun and excit-
ing environment to do their regular work. All the functionality is developed as small
widgets that perform only a specific job, like showing messages from an Exchange
Mail server, assigning tasks from a SharePoint List, or even displaying your expenses
from an internal accounting system. Just as with a regular web portal, enterprise
users can drag the widgets around and put them anywhere they like. For example, an
email inbox can be put on the left, expenses in the middle, and a list of “Phone calls
to make” on the right. A key advantage is that these widgets can provide content
from different web servers on different platforms, including Linux, Unix, or IBM
OS/2 servers. As long as the platform speaks XML and HTTP, any functionality can
Navigating Dropthings | 5
be provided in the form of a widget. The main framework takes care of authentica-
tion, authorization, user profile, communication, and all those cool Ajax effects. As a
result, the widgets are a lightweight component with a small amount of code to do
exactly what they are supposed to.
An Ajax web portal is also quite useful for group portals or social web sites. For
example, say you want to make a .NET developer group portal. You would start with
a blank page, add lots of .NET feeds, put a link widget and fill it with useful .NET
web site links, add an address book widget and fill in useful contacts, put in a calen-
dar widget to publish events for the group, and so on. With just these basic widgets
and some rearranging, you have a dynamic, personalizable developer group portal
that is state of the art in both technology and usability.
Enterprise portals especially can benefit from using Ajax web portals. Enterprise por-
tals bring in content from many sources and different platforms. By using an Ajax
widget platform, you can make the whole portal in terms of small widgets that con-
nect to different systems and serve content to the page. The benefit of such a plat-
form is that the complexity of the entire portal is dramatically reduced because it’s
just a generic widget platform.
Navigating Dropthings
When you first visit Dropthings, which I encourage you to do now, you get a pre-
defined default setup of widgets that you can customize anyway you like. For exam-
ple, there’s a Flickr photo widget, some RSS feeds, and several community
contributed widgets for weather, news, and so on (see Figure 1-3).
Figure 1-3. Your initial visit to Dropthings gives you a predefined template that can be customized
6 | Chapter 1: Introducing Web Portals and Dropthings.com
On the Dropthings Start page, you can add widgets, remove widgets that you don’t
like, and customize individual widgets by clicking on the “edit” link on each title bar.
Clicking on the “edit” link brings up the “Settings” area for the widget where you
can change its look, feel, and behavior (see Figure 1-4).
You can also drag-and-drop widgets from one column to another and reorganize the
page as you like. When you come back to the page, your customization is preserved
even if you did not sign up. However, when you sign up, your pages are saved per-
manently and you can access them from anywhere (see Figure 1-5).
It is possible to have more than one tab (page) of widgets. There’s already a pre-
created empty second tab where you can add new widgets. So from there, you can
add as many tabs as you like. This helps you keep your tabs clean and light and
groups relevant widgets in the same location.
Clicking on the “Add stuff” link on the top right of the web page brings up a pop-up
widget gallery that shows the list of available widgets (see Figure 1-6). From the list,
you can click anywhere on the widget and have it added to your page. After adding
it, you can further customize it by clicking on the “edit” link on the widget’s title bar.
Figure 1-4. The photo widget allows you to change the photo stream by clicking on “edit” link on
the title bar of widget
Navigating Dropthings | 7
At the top part of the page, there’s a bar where you can search the Internet. Search is
the most used function on the Web. Therefore, web portals need to have convenient
search functionality; otherwise users won’t set a web portal as browser homepage.
The Live.com search bar on the top provides on-site search functionality where the
search results are shown right on the page, which allows the user to perform a search
without leaving the web portal (see Figure 1-7).
Figure 1-5. You can drag and drop widgets on the page and reorganize the page as you like
Figure 1-6. Create a “Photo” tab and add a Flickr photo widget to it with Add Stuff; each photo
widget shows a specific photo stream from Flickr as defined by the widget’s settings
Widget gallery Add stuff link
Customize newly
added widget
8 | Chapter 1: Introducing Web Portals and Dropthings.com
As you use the site, you will notice there’s not a single postback of the page. Opera-
tions are performed either via asynchronous postback or via JavaScript calls from the
browser. You can add/remove widgets, drag-and-drop widgets, and switch tabs with-
out ever causing a postback or refresh of the page. This is what makes Ajax web por-
tals really convenient and fast to use compared to non-Ajax web portals.
Using ASP.NET AJAX
The web portal you’ll learn how to build is an N-tier application with a user inter-
face (UI) layer, a business layer, and a data access layer. You’ll use ASP.NET AJAX to
implement the UI layer of the web portal application, which includes the homepage
and the widget’s UI. ASP.NET AJAX provides the framework (via UpdatePanel) for
updating widgets without doing any postbacks, and it changes page layout by drag-
ging and dropping widgets on the page. It also offers a rich collection of Control
Extenders that add cool effects like fade in/fade out, smooth transitions, and client-
side animations. You can add to the rich client-side experience by providing auto-
completion behavior on text boxes, asynchronous data loading via web service calls,
client-side paging, sorting, and much more.
The ASP.NET AJAX runtime provides a framework you can use to make XML HTTP
calls from within the widgets. It also provides the framework for building client-side
effects using Custom Extenders. The drag-and-drop behavior of widgets on the page
is built as an Extender. You’ll also reuse some extenders from the Ajax Control Tool-
kit (ACT) to enrich the client user experience within the widgets.
Figure 1-7. The Live.com search bar provides on-site search functionality
Using C# 3.0 and .NET 3.5 | 9
ASP.NET AJAX exposes a handy API that you can use to authenticate against the
ASP.NET Membership application service. A good thing about the ASP.NET Mem-
bership API is that it’s fully compatible with ASP.NET AJAX and providers for Mem-
bership, Profile properties, and so on; they all work exactly the same way as a regular
ASP.NET web site. This means you can make client-side login and signup forms, and
change user preferences without requiring any postback.
Using C# 3.0 and .NET 3.5
Dropthing’s business layer is built with the Windows Workflow Foundation (WF),
which was introduced in .NET 3.0. Major operations like a first-time user visit, a
subsequent user visit, adding a new widget, and creating a new page are all orches-
trated using workflow. The workflows contain all the business rules and activities
needed to complete each operation. For example, the New User Visit workflow cre-
ates the user account, populates the user profile with default values, creates some
default pages, populates them with specific widgets, etc. Such compound operations
are very easy to build with workflows, which enable you to break the complete oper-
ation into smaller chunks called Activities. Each Activity does a very small amount of
work. It talks to the data access layer and performs the task. The data access layer is
built with .NET 3.5, using LINQ to SQL, which vastly simplifies the querying of
databases from within your application code.
The web project and the widgets make good use of .NET 3.5 by using new function-
ality for lambda expressions, LINQ to SQL, and LINQ to XML. You will use LINQ
queries to work with collections and database rows. Widgets make good use of
LINQ to XML to consume XML from external data sources.
The application is built following a typical N-tier architecture where there’s a clear
separation between the UI, business logic, and data (see Figure 1-8). For example:
Web layer
Consists of web pages, web services, resources (e.g., graphics, CSS, JavaScript,
and .resx files), and configuration settings.
Business layer
Provides the entity classes, business rules, and middle-tier caching of data to
reduce database roundtrips.
Data access layer
Encapsulates database access and provides an interface that is database and data
source independent. It also provides object factories that create Entity classes
out of database rows and vice versa.
10 | Chapter 1: Introducing Web Portals and Dropthings.com
In Figure 1-8, the technologies are mapped to each layer.
The web portal application in this book makes use of some of the newest .NET 3.0
and .NET 3.5 technologies. The web layer uses ASP.NET AJAX for a rich user expe-
rience, and the business layer uses the new WF to orchestrate complex operations.
All three layers use LINQ to work with data structures.
C# 3.0 language extensions and LINQ queries are used in all layers to work easily
with collections, database rows, and XML. WF is used in the business layer to per-
form complex operations, such as workflows. LINQ to SQL is part of both the data
access layer and the business layer. Although the insert, update, and delete opera-
tions are mostly encapsulated inside the data access layer, some queries are faster to
implement directly from the business layer. That’s why LINQ to SQL is also part of
the business layer.
Summary
Ajax web portals push Ajax technologies to their limits. Microsoft’s ASP.NET AJAX
offers a rich set of Ajax components and a robust cross-browser compatible frame-
work to harness the full power of Ajax in web portals. The new features in .NET 3.0
and 3.5 Frameworks empower architects and developers with features like Work-
flow Foundation, LINQ to SQL, and LINQ to XML. This chapter, provided a brief
overview of what an Ajax web portal can do and what technologies are involved in
making such a project. The next chapter will discuss the architectural challenges,
performance issues, and security threats that make architecting a web portal more
challenging than typical web applications.
Figure 1-8. Mapping technologies to the different layers
Web layer
ASP.NET AJAX LINQ to Xml LINQ queries
Business layer
Workflow Foundation LINQ to SQL LINQ queries
Data access layer
SQL Server 2005 LINQ queriesLINQ to SQL
Summary | 11
Additional Resources
• “Using LINQ to SQL (Part 1)” from Scott Guthrie’s blog (http://weblogs.asp.net/
scottgu/archive/2007/05/19/using-linq-to-sql-part-1.aspx)
• LINQ to XML overviews (http://msdn2.microsoft.com/en-us/library/bb308960.aspx)
• Workflow Foundation tutorials (http://wf.netfx3.com)
• The LINQ Project (http://msdn2.microsoft.com/en-us/netframework/aa904594.aspx)
http://weblogs.asp.net/scottgu/archive/2007/05/19/using-linq-to-sql-part-1.aspx
http://weblogs.asp.net/scottgu/archive/2007/05/19/using-linq-to-sql-part-1.aspx
http://msdn2.microsoft.com/en-us/library/bb308960.aspx
http://wf.netfx3.com
http://msdn2.microsoft.com/en-us/netframework/aa904594.aspx
12
Chapter 2CHAPTER 2
Architecting the Web Portal and Widgets 2
Because it strives to deliver its functionality on a single page, an Ajax web portal that
lives up to its promise is invariably a masterpiece of Ajax technology. It is a great
architectural challenge to provide so much on one page without compromising the
performance of either the server or client. Some of the unique challenges seen only in
web portals include incorporating many features into one web application and aggre-
gating content from every kind of web site.
This chapter explains the architecture of the Dropthings portal, which you can also
use to design one of your own. We’ll examine a number of architectural challenges,
including how to run many widgets on one page, load a web portal quickly, and deal
with security threats such as denial-of-service (DoS) attacks, attempts to compro-
mise user data, and more.
The heart of any web portal is its support for widgets, which is the mechanism by which
users can customize their start pages and the means by which providers can make their
services available, whether a department inside a company or a third-party, like Reuters.
In an ASP.NET implementation like the one we use in this book, Default.aspx is the
homepage that displays the widgets and allows them to be added, removed, moved,
customized, and run within the page without ever causing a page refresh or postback.
The application remembers a user’s actions and customizations so that on her next
visit she sees the exact same widgets she saw when she left, with her customizations
preserved. Web portals typically allow anonymous users to use many of their fea-
tures, including adding widgets, editing, deleting, and creating multiple pages, and
changing preferences, without registering.
A Dropthings widget is basically an ASP.NET web control. It can be a user control or
a server control, but works just like a regular web control participating in the ASP.
NET page life cycle. Widgets support postbacks, the ViewState, sessions, and caches.
The only difference is that a Dropthings widget must implement IWidget—a custom
interface—to integrate with the widget framework and use the services provided by
the core framework we use for the application. A custom-built Ajax control
Architecting the Web Portal and Widgets | 13
extender provides the drag-and-drop feature for the widgets. The widget frame-
work and its core are explained later in this chapter (see the “Using a Widget
Framework” section).
A widget is hosted inside a frame or container. The container provides the header
bar, which consists of the title, edit link, minimize/maximize buttons, and close but-
ton. The widget itself is loaded below the header bar inside the body area. Events,
such as changing the title, clicking on the edit link, minimizing/maximizing, and
closing are notified via the IWidget interface.
In a web portal, it’s important that widgets perform asynchronous postback and
fetch data asynchronously so the user experiences as few page refreshes as possi-
ble. Widgets are developed as regular ASP.NET controls with support for post-
back. So, the core widget framework used by Dropthings, which you’ll read about
shortly, takes care of hosting the widget inside UpdatePanel to ensure all postbacks
are asynchronous.
Although you can use a site like Dropthings for quite a while without registering,
registration will save the pages permanently so that when you use a different com-
puter, you can log in and get the same pages with the same widget setup. The ASP.
NET membership and profile provider allows anonymous users to have a persistent
state but convert to a registered user after signup. The page and widget states are
stored in their own tables.
Object Model
The ASP.NET membership provider contributes the user and roles. If the user has
one or more pages, each page can contain one or more widget instances. The differ-
ence between a widget and widget instance is that a widget is like a class, whereas a
widget instance is an instance of that class. For example, the Flickr photo widget is a
widget that loads photos from Flickr. When a user adds the Flickr photo widget to
the page, it becomes an instance of the Flickr widget. Although the term widget is
used throughout this book, it will actually means an instance of a widget.
Figure 2-1 shows the entire object model.
Figure 2-1. The web portal object model consists of a User, its settings (UserSetting), and associated
pages (Pages). A Page can contain Widget instances, each of which is an instance of Widget.
User
UserSetting
Pages Widgetinstances
Widget
Inherits
hashas
has
14 | Chapter 2: Architecting the Web Portal and Widgets
The object model starts with the user, which can have some settings and one or more
pages. Each page contains zero or more widget instances.
Application Components
Dropthings uses the Facade pattern to provide a single entry point to the business
layer. It provides access to internal subsystems, which deal with users, pages, wid-
gets, etc. The façade is named DashboardFacade (see Figure 2-2).
On the web layer, Default.aspx is the entry point. It uses DashboardFacade to perform
operations such as adding a new tab or widget, or storing a widget state.
DashboardFacade invokes different workflows for different operations. The workflows
do the real work and are developed using Windows Workflow Foundation (WF), as
explained in Chapter 4. Each workflow consists of one or more activities. Each activity
is like a class that performs some unit task. Activities use the DatabaseHelper and
DashboardDataContext classes to work with the database. DatabaseHelper is a class used
for performing common database operations. DashboardDataContext is generated by
LINQ to SQL and maps entities to database tables.
Data Model
To implement the data model used by the application, we use the ASP.NET mem-
bership provider’s default database tables—the aspnet_Users table contains all of the
user accounts. The schema has been extended with additional tables for other infor-
mation (see Figure 2-3).
Figure 2-2. Default.aspx calls DashboardFacade in the business layer for all operations, which, in
turn, uses workflows that work with databases via DatabaseHelper and DatabaseContext
Data access
layer
Database Helper Database Context
Business
layer
Dashboard Facade
Web
layer
Workflows
Default.aspx
Architecting the Web Portal and Widgets | 15
Some important details about the tables include:
• aspnet_Users is the default ASP.NET membership table. However, this table
contains only the anonymous user accounts. Registered user accounts are in
aspnet_membership table. They aren’t shown in Figure 2-3 because there’s no
relationship between aspnet_membership table and the tables.
• The Page table contains foreign key references on the aspnet_users table’s UserId
column.
• The Widget table contains the widget inventory or master list. It defines each
widget’s title and the location from where the widget is dynamically loaded. It
also defines the widgets created by default during a user’s first visit.
• The WidgetInstance table has the foreign key references on the PageId and
WidgetId columns, as well as the Page and Widget table’s ID columns, respectively.
• The UserSetting table has foreign key references on UserId column with aspnet_
users table’s UserId column.
Table 2-1 shows the table’s index plan and explanations.
Figure 2-3. The aspnet_Users table contains the users, while the rest of the tables are for the entities
Table 2-1. Index plan
Table Column Index type Why
Page UserID Nonclustered The user pages are loaded by WHERE UserID=
Page ID Clustered During the page edit, the page is located by its ID, which is also the
PK.
16 | Chapter 2: Architecting the Web Portal and Widgets
Some common design guidelines for choosing the right index setup:
• A clustered index is used on fields that increase continuously, e.g., auto number
integer fields. Because SQL Server physically arranges rows in the database file
based on a clustered index field, if I choose some fields that do not continuously
increase, it will be rearrange too many pages during the INSERT and DELETE
steps.
• Foreign key fields are nonclustered index types because they are not added as
increasing values.
Solution Files
The Dropthings solution consists of an ASP.NET web project and four C# projects,
available for download at www.codeplex.com/dropthings.
Default.aspx
Controls the widgets on the Start page
WidgetService.asmx
Exposes some web service methods used to access widgets on the Start page
Proxy.asmx
Allows widgets to fetch content from external sources and other web controls
that make up different parts of the Start page
WidgetContainer.ascx
The generic widget frame that hosts a widget inside it and works as a bridge
between the core framework and the real widget
The widgets are stored inside the Widgets folder. Each widget is built as a web con-
trol, and all related resources like graphics, CSS, and JavaScript are placed inside
subfolders of the Widgets folder (see Figure 2-4).
Widget ID Clustered ID is the PK and referenced by WidgetInstance. When a widget
is added, it is located by its ID.
Widget IsDefault Nonclustered On the first visit, default widgets are automatically created on the
Start page. IsDefault determines which widgets are defaults.
WidgetInstance PageId Nonclustered Widget instances are loaded page by page.
WidgetInstance ID Clustered During a single widget instance update or delete, ID is used to iden-
tify the instance.
UserSetting UserId Clustered User setting is queried by UserId.
Table 2-1. Index plan (continued)
Table Column Index type Why
Architecting the Web Portal and Widgets | 17
Update Panels
UpdatePanels allow you to update any part of the Start page asynchronously and give
any web site an Ajax look-and-feel. However, UpdatePanels are a significant drag on
the page. The more UpdatePanels you have, the slower asynchronous postbacks
become due to the processing required to locate the page part for postback and re-
render. It becomes even more complicated when you put UpdatePanels inside of
UpdatePanels. So, it is important to carefully study the layout of the page before mak-
ing architecture decisions.
On Dropthings, the entire widget area is a good candidate for an UpdatePanel
because it needs to reload when a user switches tabs. Also, the page tabs themselves
(where new tabs are added and deleted) should also be considered for an UpdatePanel
because tab operations can happen without affecting the rest of the page. The Add
Stuff widget gallery containing the collection of widgets is also inside an UpdatePanel
so that it can asynchronously come and go (see Figure 2-5).
Putting the whole widget area inside one UpdatePanel will result in poor perfor-
mance when adding and removing widgets because that entire UpdatePanel needs to
be refreshed to reflect the current widgets on the page. This would require a large
Figure 2-4. The web project’s directory shows the files that make up the site
18 | Chapter 2: Architecting the Web Portal and Widgets
amount of HTML and JavaScript for all the widgets on the page to be delivered dur-
ing the asynchronous update. So, a better strategy is to put each column inside one
UpdatePanel. Any changes made on any column will require an asynchronous update
only on the UpdatePanel of that column, not the entire widget area (see Figure 2-6).
Figure 2-5. The Dropthings home page uses three UpdatePanels
Figure 2-6. Instead of using one UpdatePanel to hold the three widgets, use three UpdatePanels,
one for each column. When a widget is added or removed from one column, only the UpdatePanel
on that column is refreshed.
Tab bar update panel
Widget area
update panel
Widget gallery
update panel
Tab bar update panel
Column update panels
Widget gallery
update panel
Architecting the Web Portal and Widgets | 19
When you drag and drop a widget from one column to another, there is no need for an
UpdatePanel refresh because the UI is already up-to-date using JavaScript. You just need
to inform the server which widget has been moved. The server can also recalculate the
new position of all the widgets, just like the client does. So, there’s no asynchronous
postback on drag and drop; it’s only needed when a new widget is added or removed.
Drag-and-Drop Operations
There are two ways to implement drag-and-drop operations: free form and column-
wise. Protopage (www.protopage.com) is a site that uses free-form drag-and-drop
functionality, where you can drag widgets anywhere on the page. The positions of
the widgets are absolute positions. But Live.com, iGoogle, and Pageflakes follow
column-wise organization. This allows you to either reorder widgets vertically
within a column or drag a widget from one column to another. Column-wise organi-
zation maintains a clean setup of the page all the time because the widgets are nicely
ordered in columns. This approach is used by most web portals (see Figure 2-7).
To implement drag-and-drop behavior between multiple columns, the page is
divided into three columns where each column is an ASP.NET Panel control. Wid-
gets can be added to any of the Panels. The drag-and-drop functionality is provided
using a custom-made extender.
There are two types of drag behavior that need to be supported: reordering of wid-
gets on the same column and moving a widget from one column to another. If we
make each column a drop zone using the IDropTarget interface in the ASP.NET
AJAX framework, then each widget that is an IDragSource can easily be dropped on
the columns. The more challenging part is to make widgets switch position within the
same column, that is, to reorder them. For example, if you move a widget downward,
Figure 2-7. A page showing drag-and-drop behavior between columns and the drop cue that
indicates where the widget can be dropped
Dragged item
Drop cue
http://www.protopage.com
20 | Chapter 2: Architecting the Web Portal and Widgets
the widget that was below the dragged widget will jump up to fill the vacant place.
Similarly, if you drag one widget over another, the second widget needs to move
down and make enough space for the first widget to be dropped. These behaviors are
implemented as Extenders, so you can easily attach the Extender to a Panel, and it
will act like an IDropTarget and provide the reorder facility.
So, how do you send the position of the widgets asynchronously to the server after a
drag-and-drop operation completes? When you complete a drag-and-drop move, it is
reflected on the UI, but the server does not know what just happened. Any kind of
postback to inform the server of the position of the widget will create a disruptive
user experience because the whole page or column will refresh. The server needs to
be informed asynchronously behind the scenes so the user doesn’t notice the wid-
gets’ positions being transmitted to the server and saved after each drag and drop.
The second challenge is to provide this entire drag-and-drop functionality in the
form of one Extender. The Extender needs to hook onto the Column Panel and make it
a drop target, as well as connect to the widget’s drag handles, which allows widgets
to be moved to any drop target.
In the next section, you’ll see how to go about adding widgets and their containers to
the Start page.
Using a Widget Framework
Dropthings makes use of a widget framework that allows you to focus on providing
features that are relevant to the widget itself without worrying about authentication,
authorization, profile, personalization, or storage. Widgets get these functions from
the widget framework, or the core, shown in Figure 2-8.
Figure 2-8. Widgets are automatically authenticated, authorized, profiled, and personalized, and
they receive storage and utility libraries from the host, which allows you to easily add more
functionality to the web portal in the form of widgets. The core coordinates these services.
Core
Authentication
and
authorization
Profile
Persistence
and
storage
Utility libraries
Widget
Using a Widget Framework | 21
Moreover, you can build widgets independently of the host project. You don’t need
the whole web portal’s web application source code in your local development com-
puter to build widgets. All you have to do is create a regular ASP.NET 2.0 web site,
create a user control, make it do what it’s supposed to do in a regular postback
model (don’t worry about JavaScript), implement a little interface, and you are done!
You don’t have to worry about Ajax and JavaScript with the widget framework I
have created for Dropthings. The architecture allows you to use regular ASP.NET 2.0
controls, Ajax Control Toolkit controls (http://www.asp.net/ajax/ajaxcontroltoolkit/
samples), and any extender in ASP.NET AJAX. Full server-side programming sup-
port is also included, and you can use .NET 2.0, 3.0, or 3.5, as well as regular View-
State and store temporary states. ASP.NET Cache can be used to cache widget data.
This approach is far better than what you would find in any current web portal
where you have to build the whole widget using only JavaScript, abide by specific
API guidelines, and follow a strict “no postback” model (see Figure 2-8).
In the Dropthings widget framework, the core does authentication and authoriza-
tion using the ASP.NET membership provider. This allows the widgets to get the
current user’s profile when loading. The core also provides widgets with a data stor-
age service to persist their states, as well as the user’s actions, such as expanding or
collapsing a widget, moving, or deleting. The communication between the widget
and the core is done via a widget container. The widget container hosts the actual
widget and works as a middleman. The widget container knows which widget
instance it is hosting and provides it with services like persistence service or event
notification. A page hosts one or more widget containers, but each widget container
hosts only one widget inside it (see Figure 2-9).
Figure 2-9. A page contains a collection of widget containers where each widget container contains
one widget
Page
Widget
Widget container
Widget
Widget container
Widget
Widget container
Widget
Widget container
Ajax Control Toolkit
http://www.asp.net/ajax/ajaxcontroltoolkit/samples
http://www.asp.net/ajax/ajaxcontroltoolkit/samples
22 | Chapter 2: Architecting the Web Portal and Widgets
A widget’s code is straightforward, and just like a regular web control, you can do
stuff inside Page_Load. You can also get events raised from ASP.NET user controls.
Widgets are similar to SharePoint Web Parts, but one advantage over Web Parts is
that you can use ASP.NET user controls instead of custom controls. User controls
give you access to Visual Studio, which you don’t have with custom controls. You
can also make a widget in one .ascx file, which requires no compilation into DLL or
deploying that DLL to a server—just copy the .ascx file from the web folder and it is
ready to use.
For example, say you wanted a widget that shows photos, perhaps from Flickr. You
can write the widget as a user control and, in the control code, handle events the
usual way for a user control. The following bit of code displays the photos when the
control is loaded onto the page:
protected void Page_Load(object sender, EventArgs e)
{
if( !base.IsPostBack )
this.ShowPictures(0);
else
this.ShowPictures(PageIndex);
}
To give the widget LinkButton controls to move between photos, write event han-
dlers for the buttons to include navigation code, just as you would for any server-
based navigation:
protected void LinkButton1_Click(object sender, EventArgs e)
{
if( this.PageIndex > 0 ) this.PageIndex –;
this.ShowPictures(this.PageIndex);
}
protected void LinkButton2_Click(object sender, EventArgs e)
{
this.PageIndex ++;
this.ShowPictures(this.PageIndex);
}
The ASP.NET page cycle works the same as ordinary page processing. Inside the
widget, you can use any ASP.NET control and write code for its events.
The Container provides the widget’s container and frame, and defines a header and a
body area. The actual widget is loaded inside the body area at runtime by the widget
container. For each widget on the page, the core creates one widget container, and
then the widget container dynamically loads the real widget inside its body area. The
widget container is part of the framework and you only have to write it once (see
Figure 2-10). However, widget developers don’t have to write containers because
they write the actual widget.
Using a Widget Framework | 23
The widget container is a user control that is dynamically created on the page for
each widget instance while the page loads. The widget itself is also a user control that
is loaded dynamically by the widget container via Page.LoadControl(“…”).
The actual widget hosted inside the container is loaded inside an UpdatePanel con-
trol. So, no matter how many times the actual widget performs a postback, the wid-
get container does not perform a postback.
Designing the Widget Container
Designing a good widget container is a matter of finding the right combination of
UpdatePanels. It is a bit difficult to first decide the best distribution of ASP.NET con-
trols inside an UpdatePanel. Putting the whole widget container inside one
UpdatePanel works well enough, and there is only one UpdatePanel per widget con-
tainer, so the overhead is small. But a problem surfaces with the extenders that are
attached to the HTML elements inside UpdatePanel. When UpdatePanel refreshes, it
removes existing HTML elements rendered by ASP.NET controls and creates new
ones. As a result, all the extenders attached to the previous HTML elements are
destroyed, unless the extenders are also inside the UpdatePanel. Putting extenders
inside the UpdatePanel means that whenever an UpdatePanel control is refreshed, a
new instance of the extenders is created and initialized. This slows UI update after a
postback, noticeably so when working with widgets on the page.
You could separate the header and body areas into multiple UpdatePanels—one
UpdatePanel would host the header area and another would host the actual widget.
This would allow you to change something on the widget and refresh the body wid-
get, but not the header, so the extenders that are attached to the header (e.g., an
extender for drag and drop) are not lost. But this means that all the extenders
attached to the header controls must be inside the header UpdatePanel, which will
Figure 2-10. A widget container is an ASP.NET web control that has a header and a body part,
which is where the widget is loaded
Header
Body
24 | Chapter 2: Architecting the Web Portal and Widgets
affect performance. So, although separating header and body areas into multiple
extenders does provide some performance improvement, it isn’t as much as you need
(see Figure 2-11).
However, for even better performance, what if the header UpdatePanel didn’t con-
tain the whole header, just the title and header buttons? When the header
UpdatePanel refreshes (for example, when a user clicks a header button), the whole
header is not recreated, only the title and buttons that are inside the UpdatePanel
control are refreshed. This way, the drag-and-drop extender that attaches to the
header panel can be put outside the UpdatePanel (see Figure 2-12).
Figure 2-11. A widget container with two UpdatePanels, one for the header area and one for the
body area where the real widget is loaded
Figure 2-12. The final design of the widget container with some elements outside the UpdatePanel
control to optimize the performance of the widget
Widget container
Update panel
Header panel
Title
Update panel
Body panel
Widget
Widget container
Header panel
Update panel
Title
Update panel
Body panel
Widget
Using a Widget Framework | 25
The WidgetContainer implementation is quite simple. There is a header area that con-
tains the title and the expand/collapse/close buttons, and a body area where the
actual widget is hosted. In the Dropthings solution folder shown in Figure 2-4, the file
WidgetContainer.ascx contains the markup for WidgetContainer (see Example 2-1).
The whole widget container is inside a panel control named Widget. The first child is
the header panel, which includes the WidgetHeaderUpdatePanel and contains the con-
tent of the header area. Inside of that is the title of the widget, some buttons to
Example 2-1. The .ascx content for the WidgetContainer
26 | Chapter 2: Architecting the Web Portal and Widgets
change the edit area, and buttons for expanding and collapsing the widget. The
WidgetBodyUpdatePanel, which hosts the real widget at runtime, is also included in
the header panel. The real widget is loaded by calling Page.LoadControl(…), and
then it’s added to the body panel. The CustomFloatingBehavior extender is also
included; it attaches to the widget header and makes the whole widget draggable.
Adding Widgets
A widget is made up of settings and body parts. The body part is always shown as
long as the widget is not minimized. The settings part is only shown when user clicks
the “edit” link on the widget header. The settings part stores customization options
for the widget. For example, with a Flickr photo widget, settings could include allow
the user to choose what type of photos to show, to enter tags, or to enter a user ID.
The settings area hides customization options from the UI until the user wants them,
but there can be as many choices as you like. The settings part can be made using a
regular ASP.NET Panel that contains all the elements for the customization area. By
default, the Panel is invisible, but the widget makes it visible when it is notified that a
user has clicked the “edit” link.
As noted earlier, widgets are created as ordinary web server controls. To integrate
widget functionality, implement the IWidget interface, which defines how the widget
container communicates with the widget (see Example 2-2).
The IWidget interface defines a way to inform the widget when to initialize the wid-
get area and restore its state. When a user clicks the “edit” link, ShowSettings
informs the widget to show the settings area. When a user clicks the maximize or
minimize links (the plus or minus icons), Maximized and Minimized functions are
called. The same happens when a user closes the widget—Closed is called and the
widget cleanups any information stored in database. These are all post-event callback
methods—actions the user has already performed and the widget reacts to.
Widgets are regular ASP.NET web controls with IWidget—a simple
interface implementation.
Example 2-2. IWidget interface
public interface IWidget
{
void Init(IWidgetHost host);
void ShowSettings( );
void HideSettings( );
void Minimized( );
void Maximized( );
void Closed( );
}
Adding Widgets | 27
Widgets get references to an interface implementation named IWidgetHost via the
IWidget.Init method. This interface exposes methods to communicate with the con-
tainer as well as the services provided by the container. IWidgetHost allows the wid-
get to consume services provided by the framework, including authentication,
notification, and state persistence. For example:
public interface IWidgetHost
{
void SaveState(string state);
string GetState( );
void Maximize( );
void Minimize( );
void Close( );
bool IsFirstLoad { get; }
}
The various methods IWidgetHost uses are as follows:
SaveState
Stores arbitrary data as XML (or any other format), but because the data needs to
be serialized in a string format, XML is the preferred choice. Whatever is stored as
the state can be retrieved using the GetState method on the second-time load.
GetState
Gets the state that you stored using SaveState.
Maximize
Maximizes the widget and shows the widget body. It’s the same as a user click-
ing the “+” button, only the widget does it itself from code.
Minimize
Minimizes the widget and hides the body area. It’s the same as a user clicking
the “-” button, only the widget does it itself from code.
Close
Removes the widget from the page permanently.
IsFirstLoad
Determines whether it’s the first-time load on the page or if an asynchronous
postback is happening either on the widget or on some other widget.
The IWidget.Init method executes before the Page_Load method of the
web control. By having the reference to IWidgetHost earlier than Page_
Load, you can use it to determine whether it’s a postback or first-time
load.
The IsFirstLoad property is tricky. Think about what happens when a user clicks
some button on a widget and the widget goes through a postback. Basically the
whole page is instantiated again and all the widgets are loaded on the server side.
Because widgets are user controls, ASP.NET fires the Page_Load method of all the
widgets on the page. Now, the widgets need to know if it’s a postback or a first-time
28 | Chapter 2: Architecting the Web Portal and Widgets
load because the content is loaded from different sources. For example, for a first-
time load, the Flickr photo widget loads the photos directly from Flickr, but on post-
back it can get the photos from ViewState or some other cache. The IWidgetHost.
IsFirstLoad property tells the widget whether it is a first-time or postback load.
You might be wondering, why not use Page.IsPostback, which comes with ASP.NET?
It will surely tell whether it’s a postback or first visit to the page. The multi-tab nature
of the Ajax web portal redefines what a first-time load is because not all tabs are
loaded on the first visit; and widgets on a tab are loaded only when the tab is acti-
vated. Imagine a user switching tabs and loading a different set of widgets, but all of
the tabs are on the same ASP.NET page. So, when you click on a tab, it’s a regular
ASP.NET asynchronous postback to the ASP.NET page. Now you are loading the
widgets on the new tab, not on the old tab. If the widgets on the new tab call Page.
IsPostback, they will find it true because clicking on a tab is a regular postback for
ASP.NET. But for the widgets that are loading for the first time on the new tab, it’s
not a postback for them. They will fail when trying to read data from ViewState
because no ViewState exists for them yet. This means the user cannot use the regular
ASP.NET postback concept for the widgets. This is why the IWidgetHost differenti-
ates regular ASP.NET postback with our own definition of postback for Widgets.
Maximizing the First-Visit Experience
The most challenging part of a web portal is the first-visit experience. On first visit, a
new user gets a page that is set up with predefined widgets that are ready for further
customization (see Figure 2-13).
Figure 2-13. The first visit to a web portal requires setting up the user account, creating pages, and
populating with predefined widgets that user can further customize
Download
ASP.NET AJAX
Core Runtime
Download HTML of
the page and start
rendering widgets
Download additional
ASP.NET AJAX
runtime scripts
Download Extender
scripts, widgets scripts
Initialize drag and drop
and other client-side
behaviors
Client-side activities
Create anonymous
user account
Create default
pages
Create default
widgets on first
page
Pre-customize
the widgets
Render the pages
and widgets on
first page
Server-side activities
Maximizing the First-Visit Experience | 29
During a first-time visit, the page does the following before the user sees it:
• Creates a new user account using a ASP.NET 2.0 membership provider
• Creates a new profile using a ASP.NET 2.0 profile provider
• Creates new pages for the user
• Creates default widgets on the first page
• Sets up widgets with default data, e.g., shows the weather in the user’s city by
inferring the user’s location based on the IP address
• Renders the widgets and any associated client script
• Delivers the entire client framework to support the web portal functionality
The challenge here is to execute server-side tasks instantly so the server does not
have a noticeable delay before it starts to deliver the page content to the browser.
Once the response is delivered, the browser needs to download the Ajax framework,
widget scripts, graphics, CSS, etc., which takes a long time. To give the user per-
ceived fast speed, the server needs to deliver the content almost instantly and pro-
gressively download the rest while the user is looking at the content of the page.
Basically, during the first visit, the application needs to deliver almost every aspect of
the web portal, because you don’t know what user might do once the page becomes
functional. With Dropthings, users can use all the features of the application on the
first visit. For example, a user can drag widgets, add new pages, and organize the
content in pages, and then sign up to continue using the customized page. The user
does all of this from a single web page with absolutely zero postback and no naviga-
tion to other pages. If postback was allowed on the page or the page was broken into
multiple pages, then we could deliver only basic content and client-side features, like
drag and drop. The rest of the functionality would be delivered when the user does
something that makes a postback to the server or navigates to a different page.
Because postback or navigation to other pages is not allowed, if the entire client
framework is not ready by the time the user starts interacting with the page, there
will be JavaScript errors and actions will fail.
At the same time, you need to ensure that providing all these features on the first
visit does not slow down first-time loading of the page. Otherwise, the first visit
experience will be slow and the user will lose interest in the site. It’s a big challenge
to make the first visit as fast as possible for the user so she can use the site immedi-
ately without getting bored looking at the browser progress bar.
The following are some ideas on how you can avoid a slow first-visit experience:
• Send HTML of the page and scripts in parallel so that the user sees something is
happening on the page while the scripts and pictures download in the back-
ground. This increases the site’s perceived speed.
30 | Chapter 2: Architecting the Web Portal and Widgets
• Download the scripts in multiple steps. First, download the core Ajax runtime
and then render the UI. This way, the user sees that something is happening and
does not become impatient.
• Start downloading the other scripts that add additional features once the wid-
gets are rendered on the UI. For example, extenders can download after the con-
tent is rendered.
• Delay downloading scripts that aren’t immediately necessarily and download
those at a later stage. Generally, users don’t use features like drag and drop
right away, which allows you to delay scripts for dialog boxes, tool tips, and
animations.
• Combine multiple small scripts in one large script file. You could create one
JavaScript file for each particular functionality. For example, each ASP.NET
extender has one or more JavaScript files. Try to keep JavaScript files small and
introduce many small files in the web applications. The browser takes about 200
to 400 ms to reach the server and come back to the browser to download a file.
So, each script file can waste 200 to 400 ms, and if there are five scripts, then the
application spends one second on each network roundtrip. Now, add the total
download time for the files, and it could easily take 10 seconds for 5 large
scripts. So, you need to seriously think about (and test) how to optimize script
file size and reduce network roundtrips as much as possible. Ideally, you should
try to deliver only one large JavaScript file that combines all the smaller Java-
Script files that are essential for the web portal to be fully functional on first visit.
Rendering a Second-Visit Experience
The second visit is piece of cake. The user account is already available from a
browser cookie, which you get via the ASP.NET membership provider. All the Ajax
scripts are already in the browser’s cache. So, you just load existing pages and wid-
gets on the page and render the page to the browser (see Figure 2-14).
Here’s what the web portal does on the second visit:
Figure 2-14. On the second visit, the user account, pages, and widgets are already created so the
user page loads very fast
Load user page
including widgets
Render page
content
Download scripts
from browser’s
cache
Download Extender
scripts, widget scripts
from cache
Initialize drag and drop
and other client-side
behaviors
Server- and client-side activities
Improving ASP.NET AJAX Performance | 31
• Gets user from encrypted browser cookie via theASP.NET membership provider
• Loads user pages and creates tabs for each page
• Finds the current page
• Loads all widgets on the current page
• Allows widgets to load their previous state
• Renders the widgets and scripts
• Delivers the client-side framework (should be cached on browser already)
Because the client-side framework, widget scripts, and extender scripts are already
cached on the browser, the duration of a second-time visit is basically the time spent
on the server and the time the browser spends initializing scripts. However, in the
meantime, the browser cache might expire and the cached JavaScript can get lost. If
this happens, the browser will download the scripts again and the user will notice
some delay during the next visit.
Improving ASP.NET AJAX Performance
There are several ways to improve your ASP.NET AJAX performance.
Server-Side Rendering Versus Client-Side Rendering
The Ajax web portal can be rendered in two ways: from the server or from the client.
Server rendering means that the HTML on a page, along with all the widgets, is cre-
ated in server code, rendered by the server code, and delivered statically to browser.
So, the browser just renders the HTML, loads the JavaScript (or Ajax framework,
extenders, widget scripts, etc.), and initializes it. iGoogle is a good example of server-
side rendering.
In contrast, client rendering means the content of the widget is not sent along with
the page content. Once the scripts download and initialize, the page calls a web ser-
vice to get the content of the widgets and dynamically creates the widgets on the
page, one after another.
The advantages of server rendering include:
• Uses server-side technologies to their full potential. For example, it makes full
use of ASP.NET features.
• Renders and delivers entire page to the client in one shot. If the page does not
have too many widgets, the perceived speed is better than client-side rendering
approach.
• Shows the content and then downloads the Ajax runtime, core scripts, widget
scripts, etc., and initializes them later. Because the user sees the widgets before
the whole page is downloaded, she feels it is a fast-loading page.
32 | Chapter 2: Architecting the Web Portal and Widgets
The disadvantages of server-side rendering include:
• The page’s cache output is delivered every time the user visits the site because it
doesn’t know if the user has already changed the page on another computer or if
the page’s content has changed by other means.
• All widgets need to be developed mostly using server-side technology like ASP.
NET. You cannot have JavaScript-only widgets.
• If a widget does not follow the ASP.NET-style postback model, it will need a lot
of support from a client-side framework. For example, you will have to provide
support for features, such as expanding, collapsing, closing, and resizing, in the
client framework and make sure the server is kept in sync with such client-side
activities via web service calls.
The advantages of client-side rendering are:
• A server-side framework for widgets is not needed.
• Widgets can provide all functionality from the client side.
• Completely client-side web portals and widgets require zero postback, not even
any asynchronous postback, which improves responsiveness.
• The response can be cached via a web service call. Thus, the next time the user
comes back, the cached response is loaded from browser cache and rendered
very fast. Just as Default.aspx is rendered from the server on every visit, you can
easily decide whether to load page content from the cache or make a fresh call to
get fresh page content if it has changed between the visits.
But the disadvantages of client-side rendering include:
• Widgets are mostly developed with JavaScript so they are a lot more difficult to
develop than regular ASP.NET web controls.
• Too much JavaScript on the client side makes the browser slow unless the user
has a powerful computer.
• Browsers’ debugging support is still very poor compared to server-side debug-
ging support.
Runtime Size Analysis
ASP.NET AJAX has a pretty big runtime that consists of the core framework, scripts
for UpdatePanel, and a preview script that is required for drag-and-drop functional-
ity. Additionally, we need the Ajax Control Toolkit. These requirements total a stag-
gering 564 KB of download for 12 script references on the page. The download size
mostly depends on the usage of extenders and Ajax features, so moderately using an
extender creates the output in Figure 2-15.
Improving ASP.NET AJAX Performance | 33
To capture traffic and simulate slow Internet speed by throttling data transfer speed,
I used a tool called Charles (www.xk72.com/charles). From the durations, you can
see almost 20 seconds is spent on downloading the runtime over a 256 kbps line!
Surely this is unacceptable speed.
The following is an explanation of what each script in Figure 2-15 does. Entries start-
ing with /Dashboard/WebResource.axd or /Dashboard/ScriptResource.axd are Java-
Script and the following list details functions by the size of the file.
21.64 KB
Handy script for postbacks
83.38 KB
Microsoft Ajax core runtime
30.16 KB
UpdatePanel, partial update, asynchronous postback scripts
136.38 KB
Preview version of Ajax that allows drag-and-drop script
36.02 KB
The actual drag-and-drop script in Preview library
45.25 KB
Ajax Control Toolkit
4.08 KB
Timer script
140.86 KB
ACT animation framework
Figure 2-15. A 256 kbps Internet speed simulation shows, which files are downloaded on the first
visit to a site
http://www.xk72.com/charles
34 | Chapter 2: Architecting the Web Portal and Widgets
18.05 KB
ACT behavior base implementation, which is required for Ajax Control Toolkit
behaviors
16.48 KB
ACT animation behavior
7.32 KB
My custom drag-and-drop behavior
9.73 KB
My custom floating behavior
The total payload for the runtime only is too high—you cannot make a user wait 20
seconds just to download Ajax scripts before she can actually start interacting with
the page. So, to reduce the size of the download:
• Eliminate the preview version of Ajax completely and use ACT for drag-and-
drop functionality
• Use IIS 6 compression to deliver compressed scripts from the client
• Combine multiple script files into one file
ACT comes with its own DragDropManager, which is needed for drag-and-drop func-
tionality. You could use Sys.Preview.UI.DragDropManager, but the DragDropManager
alone adds nearly 180 KB of scripts for the entire preview library runtime.
By using ACT’s DrgaDropManager, you can get rid of the preview runtime and improve
response delay by seven seconds.
Without the preview scripts, the scripts downloaded are shown in Figure 2-16.
When IIS 6 compression is enabled, the situation improves dramatically as shown in
Figure 2-17.
Figure 2-16. The scripts loaded without the CTP version of ASP.NET AJAX, which saves about
180 KB
Improving ASP.NET AJAX Performance | 35
The total download comes down from 448 KB to 163 KB, which is a 64 percent
reduction!
The scripts are downloaded in two steps. First the core runtimes download, and then
ACT and other scripts download. The content is displayed after the core runtime is
downloaded. So, the time it takes to show content on the browser is reduced signifi-
cantly because only 50 KB is needed to download before something is visible on the
screen, compared to 130 KB in the noncompressed mode.
ScriptManager control has a LoadScriptsBeforeUI property that you can set to false to
postpone the download of several scripts after the content is downloaded. This adds
the script references to the end of the
36 | Chapter 2: Architecting the Web Portal and Widgets
IE 6 will freeze while several initializations are happening. To avoid this, you need to
avoid putting many extenders on widgets and yet somehow deliver a rich client-side
experience. You could load extenders on demand when they are needed, e.g., post-
pone the drag-and-drop initialization. Generally, a user looks at the page for a while
before interacting with it, so you could easily postpone the drag-and-drop initializa-
tion using a delay timer. Another idea is to create extenders programmatically
instead of putting them on the ASPX or ASCX code, which will group the initializa-
tion of extenders for a later time. So, instead of this:
You can force it to happen later once the page is fully loaded and the browser is free
for some heavy JavaScript operations:
var floatingBehavior = $create(CustomDragDrop.CustomFloatingBehavior,
{“DragHandleID”:handleId, “id”:behaviorId, “name”: behaviorId}, {}, {}, child);
Comparing Debug Mode Versus Release Mode
During performance testing, make sure you turn off debug mode. If it is on, Ajax will
deliver debugged version of the scripts that are gigantic and full of debug statements.
They are so slow that you will hardly be able to drag-and-drop widgets on IE 6, even
on a dual-core machine. Once you switch to release mode, an optimized version of
the scripts is used, which is quite fast.
Adding Authentication and Authorization
Because it makes use of web services and asynchronous postbacks, a web portal is
faced with four challenges:
• Authenticating the caller and ensuring the caller is a legitimate user on all asyn-
chronous postback and web service calls.
• Authorizing calls to web services and asynchronous postbacks. Making sure the
caller has the right to make that call.
• Preventing flooding. Making sure the caller cannot continuously call the service
and flood the system.
• Preventing bots from hitting Default.aspx.
Web portals treat anonymous users the same way as a registered user. Although you
might want to disable some features for anonymous users and make them available
only to registered users, the main reason for registering is to save the pages perma-
nently because anonymous cookies can get lost. Almost all web services can be
called by any user except a user profile-related service, such as changing a user
email address.
Adding Authentication and Authorization | 37
Although it sounds like security would be easier with web portal architectures, it is
actually more complicated. For security purposes, you need to make sure each and
every web service call is made on the caller’s pages or widgets. For example, when
deleting a widget from a page, you need to verify that the widget belongs to one of
the user’s pages that just made the call. If it isn’t, then it’s definitely a hacking
attempt. Similarly, when you remove a page, you need to make sure that it belongs
to that user and not someone else. This is a big performance concern because such
checks always require database calls. If you had a registration-only site or an intra-
net-only site, you could skip these checks because you trust registered users more
than anonymous users. But, since you have to support anonymous users, you can-
not leave any web service method call unchecked. For example, when checking for a
widget, you need to get the containing page of the widget and make sure it belongs
to the user making the call. Once you are satisfied that the call is legitimate, you can
update the widget’s position. If you don’t do this, anyone can run a program and call
the service by passing an arbitrary widget ID and change other users’ page setups.
Flood attempts are another problem. Anyone can continuously call “create a new
widget” to the web service and flood the widget database with garbage widgets and
thus make the database large and slow. So, you need to implement a quota on web
service calls, e.g., a maximum of 100 calls per minute, 100 widgets per page, or 10
registrations per IP per day, etc.
Web service calls can be flooded with automated calls. DoS attempts
can render the system nonresponsive to valid web requests.
The fourth problem is related to repeated page hits. Imagine hitting a web portal
with cookies disabled. Every hit would be a first-time visit, which would force the
web portal to generate a new user, create pages, and populate the page with widgets,
which would create high database activity and enlarge database tables. So, you need
to make sure no one is flooding your system by hitting the Default.aspx continu-
ously. Also, you need to:
• Isolate bots and web crawlers
• Deliver different results from Default.aspx when a bot visits the site
• Prevent ASP.NET from creating a new anonymous user
• Create a maximum limit of cookieless hits to a page from the same IP
This last point is important, for example, an IP like 192.168.1.1 can only hit Default.
aspx 50 times an hour. But you can’t just set this to a very low value because several
users using a proxy server will show the same IP. So, the challenge is to select a thresh-
old value that does not bring down your server but also does not limit users using
proxy servers. DoS attacks and prevention are covered in detail in the next section.
38 | Chapter 2: Architecting the Web Portal and Widgets
Preventing Denial-of-Service Attacks
Web services are the most attractive target for hackers because even an unsophisti-
cated hacker can bring down a server by repeatedly calling a web service. Ajax web
portals are a good target for such DoS attacks because if you just visit the home page
repeatedly without preserving a cookie, every hit is producing a new user, a new page
setup, and new widgets.
You can try this yourself with a simple code like this:
for( int i = 0; i < 100000; i ++ )
{
WebClient client = new WebClient( );
client.DownloadString("http://www.dropthings.com/default.aspx");
}
To your great surprise, you will notice that after a couple of calls, you will simply get
no response. It’s not that you brought down the server, but that your requests are
being rejected. You no longer get any service, thus you achieve denial of service (for
yourself), and the site is happy to deny you of service (DYoS).
A simple trick to remember how many requests are coming from a particular IP is to
record a caller’s IP in the ASP.NET cache and count the requests per IP. When the
count exceeds a predefined limit, reject further requests for a specific duration, say
10 minutes. After 10 minutes, allow requests from that IP again.
The ActionValidator class maintains a count of specific actions such as first visit,
revisit, asynchronous postbacks, adding a new widget, adding a new page, etc. It
checks whether the count for a specific IP exceeds the threshold value or not. The
following code shows the enumeration that contains the type of actions to check for
and their threshold value for a specific duration, which is 10 minutes:
public static class ActionValidator
{
private const int DURATION = 10; // 10 min period
public enum ActionTypeEnum
{
FirstVisit = 100, // The most expensive one, choose the value wisely
ReVisit = 1000, // Welcome to revisit as many times as the user likes
Postback = 5000, // Not much of a problem
AddNewWidget = 100,
AddNewPage = 100,
}
A static method named IsValid does the check. It returns true if the request limit is
not passed and false if the request needs to be denied. Once you return false, you can
call Request.End( ) and prevent ASP.NET from proceeding further. You can also
switch to a page that shows something like “Congratulations! You have succeeded in
a denial-of-service attack (for you).”
Preventing Denial-of-Service Attacks | 39
public static bool IsValid( ActionTypeEnum actionType )
{
HttpContext context = HttpContext.Current;
if( context.Request.Browser.Crawler ) return false;
string key = actionType.ToString( ) + context.Request.UserHostAddress;
var hit = (HitInfo)(context.Cache[key] ?? new HitInfo( ));
if( hit.Hits > (int)actionType ) return false;
else hit.Hits ++;
if( hit.Hits == 1 )
context.Cache.Add(key, hit, null, DateTime.Now.AddMinutes(DURATION),
System.Web.Caching.Cache.NoSlidingExpiration, System.Web.Caching.
CacheItemPriority.Normal, null);
return true;
}
The cache key is built with a combination of action types and client IP addresses. It
first checks if there’s any entry in the cache for the action and the client IP. If not,
start the count and remember it for the IP cache for the specific duration. The abso-
lute expiration on a cache item ensures that after the duration, the cache item will be
cleared and the count will restart. When there’s already an entry in the cache, it will
get the last hit count and check if the limit has been exceeded. If not, then the
counter will be increased. There is no need to store the updated value in the cache
again by calling Cache[url]=hit; because the hit object is determined by reference, it
is changed in the cache every time as well. In fact, if you put it in the cache again, the
cache expiration counter will restart and fail the logic of restarting count after spe-
cific duration.
The usage is very simple:
protected override void OnInit(EventArgs e)
{
base.OnInit(e);
// Check if revisit is valid or not
if( !base.IsPostBack )
{
// Block cookie less visit attempts
if( Profile.IsFirstVisit )
{
if( !ActionValidator.IsValid(ActionValidator.ActionTypeEnum.FirstVisit))
Response.End( );
}
else
{
if( !ActionValidator.IsValid(ActionValidator.ActionTypeEnum.ReVisit) )
Response.End( );
}
}
40 | Chapter 2: Architecting the Web Portal and Widgets
else
{
// Limit number of postbacks
if( !ActionValidator.IsValid(ActionValidator.ActionTypeEnum.Postback) ) Response.
End( );
}
}
Of course you can put in a Cisco firewall and you get a guarantee from your hosting
provider that its entire network is immune to DoS and distributed DoS (DDoS)
attacks. But what they guarantee is protection against a network-level attack, such as
TCP SYN attacks or malformed packet floods. There is no way your hosting pro-
vider can analyze the packet to find out if a particular IP is trying to load the site too
many times without supporting cookies or adding too many widgets. These are
application-level DoS attacks that cannot be prevented with hardware, operating sys-
tems, or firewalls, and must be implemented in your own code.
There are very few web sites that take such precautions against application-level DoS
attacks. Therefore, it’s quite easy to make servers go mad by writing a simple loop
and hitting expensive pages or web services continuously from your home broad-
band connection.
Summary
In this chapter you learned the basics of the web portal architecture used to build
Dropthings, which encapsulates most of the client functionality that makes it easy
for developers to create widgets that plug into a web portal. In particular, you’ve
seen how use of a widget framework greatly facilitates their development and
deployment.
It can be quite challenging to provide a rich client-side experience in a web portal;
the biggest challenge is the first visit, where huge scripts must be downloaded. A web
portal is also vulnerable to certain security risks, so you must implement mitigations
that prevent them. Now that you know about the architectural challenges, let’s use
ASP.NET AJAX to build the web layer in the next chapter.
41
Chapter 3 CHAPTER 3
Building the Web Layer Using
ASP.NET AJAX3
The biggest challenge you’ll face developing an Ajax web portal is providing almost
all of your web application’s functionality on a single page. A web portal is all about
aggregating many services in one place. It’s a never-ending challenge to have as many
features on one page as possible yet keep them small, simple, and fast. So, the
Default.aspx is the most complicated of all the pages in your application because it
does everything from loading Ajax frameworks to serving the widgets on the page.
Sometimes it is the only page users will see during their entire stay on the web site.
In this chapter, you will learn to code the Start page Default.aspx, the widget container,
and the IWidget and IWidgetHost interfaces. Then you will put it all together and build a
Flickr photo widget and a RSS widget. Finally, you will use ASP.NET 2.0 Membership
and Profile providers to implement authentication, authorization, and profiles.
Implementing the Start Page of a Web Portal
The Default.aspx page in this web project is the Start page of the Ajax web portal.
(see Figure 3-1).
It contains the following:
• The header which shows a search box
• The Add Stuff area where users can add more widgets
• The tab bar
• The columns
• The footer
The Default.aspx page starts with regular ASP.NET page syntax (see Example 3-1).
42 | Chapter 3: Building the Web Layer Using ASP.NET AJAX
The code block in Example 3-1 does the following:
• Registers the WidgetContainer control, which is the web control for the widget
container.
• Adds a reference to the CustomDragDrop assembly, which contains the
CustomDragDropExtender and the CustomFloatingBehavior.
• Turns off all caching because the page must be downloaded from the server
every time a user visits. If the page is cached, then users will not see the latest
content in widgets after making changes on the page.
• Registers the header and footer web controls.
Figure 3-1. The Default.aspx page contains almost everything in the Start page
Example 3-1. Default.aspx, part 1: Declarations of external components
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_
Default" Theme="Default" EnableSessionState="False" %>
<%@ OutputCache Location="None" NoStore="true" %>
<%@ Register Src="Header.ascx" TagName="Header" TagPrefix="uc1" %>
<%@ Register Src="Footer.ascx" TagName="Footer" TagPrefix="uc2" %>
<%@ Register Assembly="AjaxControlToolkit" Namespace="AjaxControlToolkit"
TagPrefix="ajaxToolkit" %>
<%@ Register Assembly="CustomDragDrop" Namespace="CustomDragDrop" TagPrefix="cdd" %>
<%@ Register Src="WidgetContainer.ascx" TagName="WidgetContainer" TagPrefix="widget" %>
Implementing the Start Page of a Web Portal | 43
Real-Life Example: When Caching Works Against You
Problem: Caching the Default.aspx page on the user’s browser made site fail to work.
Solution: Turn off caching from Default.aspx and serve it directly from the server.
At Pageflakes, we used to cache the Default.aspx page on the user’s browser. But we
began receiving complaints that after the page loaded from the browser’s cache, user
actions—like clicking a button on a widget or adding a new widget—always failed.
We tried our best to locate the problem but could never produce it.
Sometime after this, I was in the U.S. to attend Microsoft’s MIX06. While I was at
the hotel and using the hotel’s Internet connection, I encountered the problem
myself. Pageflakes was my browser homepage, and it loaded as soon as I started the
browser for the first time. But when I tried to use the site, all XML HTTP calls failed.
If I did a hard refresh, everything worked fine. After using the Fiddler Tool for a bit,
which shows all HTTP requests and responses, I found that hotel had an intermedi-
ate Welcome page that loaded when you accessed the Internet for the first time to
make sure the user is legitimate. As the Default.aspx page was coming from the
cache, there was no request sent to the server and thus the hotel Internet provider
could not validate who was using the Internet. So, all XML HTTP calls trying to
reach the server were redirected to the Welcome page and failed. The same problem
happened when I tried to access Pageflakes from Starbucks or from airport Wi-Fi
zones. So, we turned off caching from Default.aspx and instead made sure that it was
always served from our server and the problem disappeared. We stopped receiving
complaints too.
The Header Area
The header area displays the logo, the search bars for Live.com and Google, and the
Login link. After the header area, there’s a script block that contains some client-side
scripts that I will explain later on. These scripts are used to provide some client-side
behaviors like calling a web service when dragging and dropping, showing/hiding ele-
ments, and so on.
Example 3-2 shows the start of the
We provide professional writing services to help you score straight A’s by submitting custom written assignments that mirror your guidelines.
Get result-oriented writing and never worry about grades anymore. We follow the highest quality standards to make sure that you get perfect assignments.
Our writers have experience in dealing with papers of every educational level. You can surely rely on the expertise of our qualified professionals.
Your deadline is our threshold for success and we take it very seriously. We make sure you receive your papers before your predefined time.
Someone from our customer support team is always here to respond to your questions. So, hit us up if you have got any ambiguity or concern.
Sit back and relax while we help you out with writing your papers. We have an ultimate policy for keeping your personal and order-related details a secret.
We assure you that your document will be thoroughly checked for plagiarism and grammatical errors as we use highly authentic and licit sources.
Still reluctant about placing an order? Our 100% Moneyback Guarantee backs you up on rare occasions where you aren’t satisfied with the writing.
You don’t have to wait for an update for hours; you can track the progress of your order any time you want. We share the status after each step.
Although you can leverage our expertise for any writing task, we have a knack for creating flawless papers for the following document types.
Although you can leverage our expertise for any writing task, we have a knack for creating flawless papers for the following document types.
From brainstorming your paper's outline to perfecting its grammar, we perform every step carefully to make your paper worthy of A grade.
Hire your preferred writer anytime. Simply specify if you want your preferred expert to write your paper and we’ll make that happen.
Get an elaborate and authentic grammar check report with your work to have the grammar goodness sealed in your document.
You can purchase this feature if you want our writers to sum up your paper in the form of a concise and well-articulated summary.
You don’t have to worry about plagiarism anymore. Get a plagiarism report to certify the uniqueness of your work.
Join us for the best experience while seeking writing assistance in your college life. A good grade is all you need to boost up your academic excellence and we are all about it.
We create perfect papers according to the guidelines.
We seamlessly edit out errors from your papers.
We thoroughly read your final draft to identify errors.
Work with ultimate peace of mind because we ensure that your academic work is our responsibility and your grades are a top concern for us!
Dedication. Quality. Commitment. Punctuality
Here is what we have achieved so far. These numbers are evidence that we go the extra mile to make your college journey successful.
We have the most intuitive and minimalistic process so that you can easily place an order. Just follow a few steps to unlock success.
We understand your guidelines first before delivering any writing service. You can discuss your writing needs and we will have them evaluated by our dedicated team.
We write your papers in a standardized way. We complete your work in such a way that it turns out to be a perfect description of your guidelines.
We promise you excellent grades and academic excellence that you always longed for. Our writers stay in touch with you via email.