Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/ruby-on-rails-4/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 我可以处理aspx中的英国错误吗?_C#_Error Handling_Custom Error Pages - Fatal编程技术网

C# 我可以处理aspx中的英国错误吗?

C# 我可以处理aspx中的英国错误吗?,c#,error-handling,custom-error-pages,C#,Error Handling,Custom Error Pages,“/”应用程序中出现服务器错误。无法在中插入重复的键行 对象“dbo.Articles”具有唯一索引“UK_Articles”。声明 已经终止 描述:在执行过程中发生未处理的异常 当前的web请求。请查看堆栈跟踪以了解更多信息 有关错误的信息及其在代码中的来源 异常详细信息:System.Data.SqlClient.SqlException:无法插入 对象“dbo.Articles”中具有唯一索引的重复键行 “UK_文章”。声明已终止 我可以代替内部服务器错误500显示UK错误吗?我能捕捉到错

“/”应用程序中出现服务器错误。无法在中插入重复的键行 对象“dbo.Articles”具有唯一索引“UK_Articles”。声明 已经终止

描述:在执行过程中发生未处理的异常 当前的web请求。请查看堆栈跟踪以了解更多信息 有关错误的信息及其在代码中的来源

异常详细信息:System.Data.SqlClient.SqlException:无法插入 对象“dbo.Articles”中具有唯一索引的重复键行 “UK_文章”。声明已终止

我可以代替内部服务器错误500显示UK错误吗?我能捕捉到错误并以某种方式显示出来吗

编辑:


但是NHibernateSession.Save(实体)总是使用GenericADOException,而从不使用SqlException。我想在nhibernate上捕获insert,这样我就可以对其进行全局搜索。

您可以使用web.config显示手动错误

<customErrors mode="On" defaultRedirect="~/ErrorPage.aspx">
  <error statusCode="500" redirect="~/500Error.aspx" />
</customErrors>

您可以使用web.config显示手动错误

<customErrors mode="On" defaultRedirect="~/ErrorPage.aspx">
  <error statusCode="500" redirect="~/500Error.aspx" />
</customErrors>

我假设您正在使用Sql Server

您需要一个
try catch
块来处理


我假设您正在使用Sql Server

您需要一个
try catch
块来处理


catch(SqlException){…}
?或者只是一个自定义错误页?你最好在插入之前检查一下是否有重复…@Paddy,我想你可以将此作为答案发布。@gaearon-这不是一个完整的解决方案,没有什么特别的方法可以阻止某人在你的存在检查和插入之间添加一个,但这确实取决于您的系统。我只是担心这里的所有答案都集中在处理这个特定错误上,而忽略了真正的问题(行键是重复的,OP需要找出导致问题的列,并确定a)是否需要索引,b)如何在错误发生之前优雅地处理重复项)。
catch(SqlException){…}
?或者只是一个自定义错误页?在插入之前,你最好先检查一下是否有重复的内容…@Paddy,我想你可以将此作为答案发布。@gaearon-这不是一个完整的解决方案,没有什么可以特别阻止某人在你的存在检查和插入之间添加一个,但这确实取决于在您的系统上。我只是担心这里的所有答案都集中在处理这个特定错误上,而忽略了真正的问题(行键重复,OP需要找出导致问题的列,并确定是否需要a)索引,b)如何在错误发生之前优雅地处理重复项)nhibernate@senzacionale,尝试获取GenericADOException的内部异常,并检查其SqlException和比较所需结果的异常号I alwys在插入时是否获取GenericADOExceptionnhibernate@senzacionale,尝试获取GenericADOException的内部异常,并检查其是否为SqlException,并比较异常号以获得所需的结果
try
{
    // run inser or update query here
    myObj.InserRow();
}
catch (System.Data.SqlClient.SqlException ex)
{
    if (ex.Number == 2601)
    {
        //"duplicate entry found!";
    }
    else
    {
        // some other kind of sql related exception
    }
}
catch (Exception ex)
{
    // any other exception
}