Skip to main content

getContextRoot() in CFMX 7

Maybe others aren't as excited about this as I am, but having the getContextRoot() method available in Java/JSP applications has always been extremely handy, and I was just bemoaning the lack of this in CFMX the other day.

Bemoan no more! I finally had a chance to go over the CFMX 7 feature list in detail, and this one slipped by me: getContextRoot() is now available in CFMX 7. This will make writing context root-agnostic applications a lot simpler and is generally just a handy function to have available. One more reason to dive into CFMX 7!


I have to agree 100%. I was not even aware of this until I read your blog. I then checked the live docs to make sure this wasnt some crule joke :). This will save alot of varing and time, nice find. I also read your presentation on OOP, great job!

OK... what does it do... and how do you use it? Don't just be elated... tell others what it does for you and us.

This kind of thing has been around a while. <a href="">try here</a> for some javadoc on the method. Hope that answers your question.

Whoops, guess I broke the law of Blog HTML up there. I'll copy and paste the interesting part of the doc below. Hope this helps. public static String getContextRoot(String applicationName, String webAppName) throws Retrieve the context root for a webapp. The context root can be used to build a URL to access that webapp. The context root is specified in either the application's or the webapp's deployment descriptors. This can be used when a webapp needs to build an absolute URL to itself, or a URL to some other webapp

Sorry, I guess I was operating under the assumption "if you've needed this you'll know what it is and be happy that it's there ..." Basically in the J2EE world you can have multiple "servers" (virtual servers in essence) running on a single Java application server. In most cases, however, only one of these virtual servers can have a context root of /, meaning you don't have to add anything extra to the URL to get to your server's contents. So what's a context root? A context root is basically a "base URL" that's unique to each server, and this translates into the part of the URL that would appear immediately following the host name. What this does on the J2EE server side is that it uses that context root to determine which application needs to respond to the request. So a typical situation in my server setup is I'll have a production instance of ColdFusion running at the / context root, and a dev instance running at something like /cfusion for a context root. So what problems does this cause? Well, in your application you have to account for context root. So when I want to move an app from dev to production, the context root is going to change. I've handled this various ways such as by checking the server name in Application.cfm and setting the context root as an application variable, etc. While that works, it wasn't the same way you do things in the Java world. In a Java application you would just slap getContextRoot() before things in your application that you know need the context root to operate correctly (e.g. image paths, etc.). So now we can do this same simple thing in CFMX 7 and not worry about having to set a variable to handle it. Cool stuff.

Hi Matt,

I used this just today!

Currently we have a page that uses cflocation. I have changed this to a server side redirect in the belief that it will work with search engines. Can anyone confirm this?


Popular posts from this blog

Installing and Configuring NextPVR as a Replacement for Windows Media Center

If you follow me on Google+ you'll know I had a recent rant about Windows Media Center, which after running fine for about a year suddenly decided as of January 29 it was done downloading the program guide and by extension was therefore done recording any TV shows.

I'll spare you more ranting and simply say that none of the suggestions I got (which I appreciate!) worked, and rather than spending more time figuring out why, I decided to try something different.

NextPVR is an awesome free (as in beer, not as in freedom unfortunately ...) PVR application for Windows that with a little bit of tweaking handily replaced Windows Media Center. It can even download guide data, which is apparently something WMC no longer feels like doing.

Background I wound up going down this road in a rather circuitous way. My initial goal for the weekend project was to get Raspbmc running on one of my Raspberry Pis. The latest version of XBMC has PVR functionality so I was anxious to try that out as a …

Running a Django Application on Windows Server 2012 with IIS

This is a first for me since under normal circumstances we run all our Django applications on Linux with Nginx, but we're in the process of developing an application for another department and due to the requirements around this project, we'll be handing the code off to them to deploy. They don't have any experience with Linux or web servers other than IIS, so I recently took up the challenge of figuring out how to run Django applications on Windows Server 2012 with IIS.

Based on the dated or complete lack of information around this I'm assuming it's not something that's very common in the wild, so I thought I'd share what I came up with in case others need to do this.

This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.

Assumptions and CaveatsThe operating system is Windows Server 2012 R2, 64-bit. If another variant of the operating system is being used, these instructions may not work properly.All of the soft…

Setting Up Django On a Raspberry Pi

This past weekend I finally got a chance to set up one of my two Raspberry Pis to use as a Django server so I thought I'd share the steps I went through both to save someone else attempting to do this some time as well as get any feedback in case there are different/better ways to do any of this.

I'm running this from my house (URL forthcoming once I get the real Django app finalized and put on the Raspberry Pi) using I don't cover that aspect of things in this post but I'm happy to write that up as well if people are interested.

General Comments and Assumptions

Using latest Raspbian “wheezy” distro as of 1/19/2013 (’lll be using Nginx ( as the web server/proxy and Gunicorn ( as the WSGI serverI used heavily as I was creating this, so many thanks to the author of that tutorial. If you’re looking for more details on …