30
2004
Exceptions crossing Tiers (and using ResourceBundles with Exceptions)
Well, I’ve been doing tons of reading on exception handling to try and develop a standard set of practices. I’ve got two immediate problems that I need to address and haven’t found much advice on:
1. Exceptions Crossing Tier Boundaries: Many of our systems are n-Tier and exceptions visible in the most remote layers aren’t necessarily available in the presentation tier. What to do?
I want to preserve the stack trace if at all possible, so I’m thinking of wrapping just the stack trace in another (presentation-tier-visible) exception and passing that on.
Alternatively, I can just log the exception (and stack trace), then rethrow a brand new exception to the client (with some sort of user-meaningful error message).
2. Externalising Error Codes and Messages: From a helpdesk point of view, it would be nice to be able to associate a numeric id with each exception. Then a client can report “Error 67: Internal Data Store Problems” appears on my screen, but the helpdesk knows that error 67 actually relates to incorrect database credentials, or whatever.
My initial thoughts are maybe to use something like a ResourceBundle, but maybe some custom descendant like a JDBCResourceBundle – where I could keep all my messages in a database (except for if the database fails
. My code could then pass a constant like DB_CREDENTIAL_FAILURE to the bundle and retrieve a nice-ish message like “Internal Data Store problems have been encountered talking to server {0}.” And do some nice MessageFormat calls to tidy things up.
Anyways, I’m interested to hear what you guys are doing with Cross-Tier exceptions and externalising Error strings. All ideas welcome.
1 Comment + Add Comment
Leave a comment
Glen Smith
Archives
- April 2012
- March 2012
- January 2012
- November 2011
- October 2011
- September 2011
- August 2011
- July 2011
- June 2011
- April 2011
- March 2011
- January 2011
- November 2010
- October 2010
- September 2010
- August 2010
- July 2010
- June 2010
- May 2010
- April 2010
- February 2010
- January 2010
- December 2009
- November 2009
- October 2009
- September 2009
- August 2009
- July 2009
- June 2009
- May 2009
- April 2009
- March 2009
- December 2008
- November 2008
- October 2008
- September 2008
- August 2008
- July 2008
- June 2008
- May 2008
- April 2008
- March 2008
- February 2008
- January 2008
- December 2007
- November 2007
- October 2007
- September 2007
- August 2007
- July 2007
- June 2007
- May 2007
- April 2007
- March 2007
- February 2007
- January 2007
- December 2006
- November 2006
- October 2006
- September 2006
- August 2006
- July 2006
- June 2006
- May 2006
- April 2006
- March 2006
- February 2006
- January 2006
- December 2005
- November 2005
- October 2005
- September 2005
- August 2005
- July 2005
- June 2005
- May 2005
- April 2005
- March 2005
- February 2005
- January 2005
- December 2004
- November 2004
- October 2004
- September 2004
- August 2004
- July 2004
- June 2004
- May 2004
- March 2004
- February 2004
- January 2004
- December 2003
- November 2003
- October 2003
- September 2003

An article by Glen





We have been using logging errors and identifying them with error codes that end-users can report to us in our new application. In addition, an e-mail is sent whenever an error occurs (unless the error is with the mailing itself).
This has been working great for us and cut debugging time by multiple factors.