X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mcs%2Fclass%2FSystem.Web%2FSystem.Web%2FHttpException.cs;h=6385ffe7cb325273c38e77e17cc1d297dcaada43;hb=60f847468e0e5740947aea5e0df987bc6b052e77;hp=e64185a785f3e2d622db222de4f8ae5627c1b00c;hpb=5bbfa8860b090e465a3aa45edeb9c94481ef1a22;p=mono.git diff --git a/mcs/class/System.Web/System.Web/HttpException.cs b/mcs/class/System.Web/System.Web/HttpException.cs index e64185a785f..6385ffe7cb3 100644 --- a/mcs/class/System.Web/System.Web/HttpException.cs +++ b/mcs/class/System.Web/System.Web/HttpException.cs @@ -36,6 +36,7 @@ using System.Security.Permissions; using System.Text; using System.Web.Util; using System.Web.Compilation; +using System.Collections.Specialized; namespace System.Web { @@ -47,8 +48,15 @@ namespace System.Web #endif public class HttpException : ExternalException { + const string DEFAULT_DESCRIPTION_TEXT = "Error processing request."; + const string ERROR_404_DESCRIPTION = "The resource you are looking for (or one of its dependencies) could have been removed, had its name changed, or is temporarily unavailable. Please review the following URL and make sure that it is spelled correctly."; + int http_code = 500; - + string resource_name; + string description; + + const string errorStyleFonts = "\"Verdana\",\"DejaVu Sans\",sans-serif"; + public HttpException () { } @@ -68,13 +76,28 @@ namespace System.Web http_code = httpCode; } + internal HttpException (int httpCode, string message, string resourceName) : this (httpCode, message) + { + resource_name = resourceName; + } + + internal HttpException (int httpCode, string message, string resourceName, string description) : this (httpCode, message, resourceName) + { + this.description = description; + } + #if NET_2_0 - protected HttpException (SerializationInfo info, StreamingContext context) + protected +#else + internal +#endif + HttpException (SerializationInfo info, StreamingContext context) : base (info, context) { http_code = info.GetInt32 ("_httpCode"); } +#if NET_2_0 [SecurityPermission (SecurityAction.Demand, SerializationFormatter = true)] public override void GetObjectData (SerializationInfo info, StreamingContext context) { @@ -100,57 +123,213 @@ namespace System.Web http_code = httpCode; } + internal HttpException (int httpCode, string message, Exception innerException, string resourceName) + : this (httpCode, message, innerException) + { + resource_name = resourceName; + } + public string GetHtmlErrorMessage () { - if (!(this.InnerException is HtmlizedException)) - return GetDefaultErrorMessage (); - - return GetHtmlizedErrorMessage (); + try { + HttpContext ctx = HttpContext.Current; + if (ctx != null && ctx.IsCustomErrorEnabled) { + if (http_code != 404 && http_code != 403) + return GetCustomErrorDefaultMessage (); + else + return GetDefaultErrorMessage (false); + } + + if (!(this.InnerException is HtmlizedException)) + return GetDefaultErrorMessage (true); + + return GetHtmlizedErrorMessage (); + } catch (Exception ex) { + Console.WriteLine (ex); + + // we need the try/catch block in case the + // problem was with MapPath, which will cause + // IsCustomErrorEnabled to throw an exception + return GetCustomErrorDefaultMessage (); + } } internal virtual string Description { - get { return "Error processing request."; } + get { + if (description != null) + return description; + + return DEFAULT_DESCRIPTION_TEXT; + } + + set { + if (value != null && value.Length > 0) + description = value; + else + description = DEFAULT_DESCRIPTION_TEXT; + } } - - string GetDefaultErrorMessage () - { - StringBuilder builder = new StringBuilder ("\r\n
\r\n", Description); - builder.Append ("Error Message: "); + string GetCustomErrorDefaultMessage () + { + StringBuilder builder = new StringBuilder (); + WriteFileTop (builder, "Runtime Error"); +#if TARGET_J2EE //on portal we cannot know if we run locally + if (!HttpContext.Current.IsServletRequest) + builder.Append ( +@"
Description: An application error occurred on the server. The current custom error settings for this application prevent the details of the application error from being viewed (for security reasons).
+Details: To enable the details of this specific error message to be viewable, please create a <customErrors> tag within a "web.config" configuration file located in the root directory of the current web application. This <customErrors> tag should then have its "mode" attribute set to "Off".
++ +<!-- Web.Config Configuration File --> + +<configuration> + <system.web> + + <customErrors mode="Off"/> + </system.web> +</configuration>+ |
Description: An application error occurred on the server. The current custom error settings for this application prevent the details of the application error from being viewed remotely (for security reasons)." + ( + " It could, however, be viewed by browsers running on the local server machine.") + + @"
+Details: To enable the details of this specific error message to be viewable on remote machines, please create a <customErrors> tag within a "web.config" configuration file located in the root directory of the current web application. This <customErrors> tag should then have its "mode" attribute set to "Off".
++ +<!-- Web.Config Configuration File --> + +<configuration> + <system.web> + + <customErrors mode="Off"/> + </system.web> +</configuration>+ |
Notes: The current error page you are seeing can be replaced by a custom error page by modifying the "defaultRedirect" attribute of the application's <customErrors> configuration tag to point to a custom error page URL.
++<!-- Web.Config Configuration File --> + +<configuration> + <system.web> + <customErrors mode="RemoteOnly" defaultRedirect="mycustompage.htm"/> + + </system.web> +</configuration> |
Description: "); + if (http_code != 0) builder.AppendFormat ("HTTP {0}. ", http_code); + builder.Append (http_code == 404 ? ERROR_404_DESCRIPTION : HtmlEncode (Description)); + builder.Append ("
\r\n"); - builder.AppendFormat ("{0}\r\n\r\n", HtmlEncode (this.Message)); - - if (InnerException != null) { - builder.AppendFormat ("Stack Trace: "); - builder.Append ("
"); - WriteTextAsCode (builder, InnerException.ToString ()); -#if TARGET_J2EE //Required, because toString of Java doesn't print stackTrace - WriteTextAsCode (builder, InnerException.StackTrace); -#endif - builder.Append (" |
\r\n"); + if (resource_name != null && resource_name.Length > 0) + builder.AppendFormat ("
Requested URL: {0}
\r\n", resource_name); + + if (showTrace && baseEx != null && http_code != 404 && http_code != 403) { + builder.Append ("Stack Trace:
"); + builder.Append (""); + WriteTextAsCode (builder, baseEx.ToString ()); + builder.Append (" |