public class ErrorController : Controller
{
public ActionResult Index(int status, Exception error)
{
Response.StatusCode = status;
ViewBag.status = status;
return View(status);
}
protected override void Dispose(bool disposing)
{
base.Dispose(disposing);
}
}
protected void Application_Error(object sender, EventArgs e)
{
var ex = Server.GetLastError().GetBaseException();
Server.ClearError();
var routeData = new RouteData();
routeData.Values.Add("controller", "Error");
routeData.Values.Add("action", "Index");
if (ex.GetType() == typeof(HttpException))
{
var httpException = (HttpException)ex;
var code = httpException.GetHttpCode();
routeData.Values.Add("status", code);
}
else
{
routeData.Values.Add("status", 500);
}
routeData.Values.Add("error", ex);
IController errorController = new trialerror.Controllers.ErrorController();
errorController.Execute(new RequestContext(new HttpContextWrapper(Context), routeData));
}
protected void Application_EndRequest(object sender, EventArgs e)
{
if (Context.Response.StatusCode == 401)
{ // this is important, because the 401 is not an error by default!!!
throw new HttpException(401, "You are not authorised");
}
}
@{
ViewBag.Title = "Index";
}
<h2>Index</h2>
<html>
<head>
<title> Error</title>
</head>
<body>
<div>
@{
int x=ViewBag.status;
}
<p style=" color: Red;">
@switch (x) {
case 401: {
<span>PAGE NOT FOUND</span>
}
break;
case 403: {
<span>FORBIDDEN</span>
}
break;
case 404: {
<span>We have experienced a 404 error.Site temporarily down</span>
}
break;
case 500: {
<span>please refresh page and try again!</span>
}
break;
//and more cases for more error-codes...
default: {
<span>Unknown error!!!</span>
}
break;
}
</p>
</div>
</body>
</html>
代码可以为案例中的所有错误提供自定义页面。但是现在我想从try -catch方法中捕获所有异常,例如db exception,并以自定义方式显示它。
示例:“空值异常或连接字符串异常”。
我怀疑的是我如何能够为此提供一些案例。我不知道要继续吗?
答案 0 :(得分:0)
但现在我想从try -catch方法中捕获所有异常,例如db exception,并以自定义方式显示它
两个选项:
让异常转义(throw
中没有参数的catch
会重新抛出相同的异常),并按照正常的路线进行,否则无法处理异常。
重定向,与任何其他控制器/操作重定向到ErrorController.Action
#2留下了将异常对象传递给控制器的问题(在错误控制器中需要一个不同的代码路径来获取传递Exception
实例的两种方法),所以#1通常是更容易的选择。