我正在为asp.net mvc项目编写一个类库。类库将返回实体并执行基本功能。在以前的项目中,我用这样的逻辑:返回错误消息vs抛出异常
public class MyClassLibrary
{
public Response<ResponseMessage, MyEntity> GetMyEntity()
{
//Some code
}
public ResponseMessage SaveMyEntity(MyEntity e)
{
//Some code
}
}
public class BaseController:Controller
{
public ActionResult JsonDataSourceRequest<T>(Func<Response<ResponseMessage, List<T>>> operation, [DataSourceRequest] DataSourceRequest request)
{
try
{
Response<ResponseMessage, List<T>> ret = operation();
if (ret.message.type == ReturnType.OK)
{
return Json(ret.result.ToDataSourceResult(request), JsonRequestBehavior.AllowGet);
}
else
return ConvertToJson(ret.message);
}
catch (Exception ex)
{
ResponseMessage m = new ResponseMessage();
m.type = ReturnType.ERROR;
m.text = ex.text;
return ConvertToJson(m);
}
}
public ActionResult PartialView<T>(Func<Response<ResponseMessage, T>> operation)
{
//Some code
}
public ActionResult Action(Func<ResponseMessage> operation)
{
//some code
}
}
[CustomAuthorize]
public class MyController : BaseController
{
public ActionResult MyEntityRead([DataSourceRequest] DataSourceRequest request)
{
return base.JsonDataSourceRequest(() =>
{
return MyEntityService.GetAll();
}, request);
}
}
在这里,为了使用BaseController的功能,我总是返回 响应 或 ResponseMessage
现在我认为我可以有自定义的异常类而不是从所有可以抛出这些异常的方法中返回ResponseMessage。
我不知道这是否是一种好的做法。
在此先感谢。
非常感谢nvoigt和@darin的快速反应。你认为与项目规则有关的错误是否例外?例如, throw UserCannotBeYoungerThan18(“”); 不好? 我应该像“处理可以处理的每一个问题”这样的座右铭吗? – aldebaran