Archive for December, 2006

Detecting the default browser…

Posted in Microsoft.NET on December 21, 2006 by vasudevan

On Oct 18, I wrote a article on showing hyperlinks from a WinForms 2.0 application. In that article, I also mentioned that I will be writing a article to check the default browser instead of hard coding the .exe file for Internet Explorer. Now this article discusses that technique.

private enum ShowCommands
SW_HIDE = 0,
SW_SHOW = 5,
SW_MAX = 11

static extern IntPtr ShellExecute(
IntPtr hwnd,
string lpOperation,
string lpFile,
string lpParameters,
string lpDirectory,
ShowCommands nShowCmd);

IntPtr ptr = IntPtr.Zero;
ptr = ShellExecute(IntPtr.Zero, “open”, “”, “”, “”, ShowCommands.SW_NORMAL);

What is happening here is ShellExecute Win32 API call is reading the registry entry at HKEY_CLASSES_ROOT\HTTP\shell\open\command. If you would like to delve under the hood on what is happening in the registry try Regmon. We can make this code more robust by checking whether the entry at that registry location is empty and ask the user to set the default browser in the registry which is pretty easy to do.


The power of IHttpModule…

Posted in Microsoft.NET on December 13, 2006 by vasudevan

I have been reading Marco Bellinaso’s ASP.NET 2.0 Website Programming Problem – Design – Solution. To begin with, the topic that I was interested in was the selectable theme technique explained in Chapter 2 (pages 38 – 41). I thought about his approach and I should admit that the idea was very good, but I was still not convinced and decided to code it using a more efficient approach using IHttpModule. IHttpModule is powerful and efficient enough and this is how I achieved the same functionality:

1. In my approach, there is no need for the ThemeSelector user control. I added the DropDownlist control in the Master page itself. Everybody knows that there is no Page_PreInit() event for Master pages. But, to set a user selectable theme at runtime, Page_PreInit() is the only event that is pluggable for theme selection.
2. On the Page_Load of the master page, code as shown in page 38.
3. On page 39 of his book, there is a bug in the GetThemes() method that returns themes string array. The variable themes is unreachable. So, modify your code to fix that.
4. Create a new regular folder under App_Code by name Modules.
5. Create a new class and name it ThemeModule.cs and copy the following code by overwriting all of the code in your class:

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Web.Configuration;

public class ThemeModule : IHttpModule
public void Init(HttpApplication application)
application.PreRequestHandlerExecute +=new EventHandler(application_PreRequestHandlerExecute);

public void Dispose()

private void application_PreRequestHandlerExecute(object sender, EventArgs e)
Page page = HttpContext.Current.CurrentHandler as Page;
if (page != null)
page.EnableTheming = true;
page.PreInit +=new EventHandler(page_PreInit);
public void page_PreInit(object sender, EventArgs e)
Page page = (Page)sender;
if (page != null)
if (HttpContext.Current.Request.Form["__EVENTTARGET"] == "ctl00$ddlThemes")
page.Theme = (string)HttpContext.Current.Request.Form["ctl00$ddlThemes"];
HttpContext.Current.Session["CurrentTheme"] = page.Theme;
if (HttpContext.Current.Session["CurrentTheme"] != null)
page.Theme = (string)HttpContext.Current.Session["CurrentTheme"];
PagesSection pagesSection = (PagesSection)ConfigurationManager.GetSection("system.web/pages");
page.Theme = pagesSection.Theme;
HttpContext.Current.Session["CurrentTheme"] = page.Theme;

All the code does is to check whether the page is requested for the first time. If it is, it reads web.config for the pages section and gets the theme entry and stores the value in a session variable. If the same user requests the same page or some other page, the theme will be loaded from the session. Lastly, if the same user selects a different theme from the dropdownlist, the code checks for postback information by reading the __EVENTTARGET and reading the value of the control’s unique id (ctl00$ddlThemes) and rewrites the session variable.

This code is definitely more efficient than coding a base page that derives from the System.Web.UI.Page and having to change it for every new page you create. Also, this approach is completely transparent and there is nothing that the other developer should do to use this.

Btw, don’t forget to configure your web.config like this:

<httpModules><add name =ThemeModule type=ThemeModule/></

httpModules><pages theme=TemplateMonster masterPageFile=~/Template.master />

ObjectDataSource, GridView and .NET Web Services

Posted in Microsoft.NET on December 11, 2006 by vasudevan

To the best of my knowledge, most of the sites that talk about GridView and business objects in .NET 2.0 explain the steps involved in creating those business objects and using ObjectDataSource control to bind to GridView control. But, what if you have to interface through web services and cannot access the business object directly? Its pretty easy. The following are the steps involved in binding web services to ObjectDataSoure control.

1. Add a web reference to the web service.
2. On a ASP.NET web form, drag GridView control and click on the Choose Data Source from the list of available entries.
3. Select Object from the list of data source types.
4. On the next page, the list of business objects shows all public methods from the web service. You should be careful to select the main name for the webservice. (e.g) localhost.MyWebService
5. On clicking Next, choose a method that you would like to run.
6. If you would like to enable paging, this is the time to do so.
7. Press F5 to check your results.