确保不要阻止方法返回作为方法参数一部分的正常结果,尤其是作为输出参数。 这些类型的错误视为非关键性错误。 错误作为输出参数而非异常的一部分返回的原因是,抛出异常将使代码偏离正常的执行路径,这是非关键性错误不希望发生的。 检查这些错误为可选操作。 这些类型的错误也称为“继续”警告。
有两种类型的警告:"停止"和"继续"。
"停止"警告
“停止”警告会导致当前操作停止。 这意味着工作簿将在执行当前操作之前回滚到其状态。 “停止”警告公开为 SOAP 异常。
"继续"警告
"继续"警告通常为警告或非关键性错误。 当 Excel Calculation Services 抛出"继续"警告时,操作继续。 这些警告返回为输出参数具有多个警告字段的结构。 有关详细信息,请参阅
Microsoft.Office.Excel.Server.WebServices
命名空间中的
Status
类参考主题。
要捕获的异常
您应该捕获您知道用户可能导致的 Excel Calculation Services 特定错误。 例如,如果您的应用程序提示用户键入工作簿路径,用户可能会键入错误的路径或者选择一个不存在的工作簿。 您无法控制用户类型,但可以控制用户无意中拼错工作簿文件名时的用户体验。
您应该捕获代码中的 SOAP 异常(即"停止"警告)。 对于“继续”警告,调用代码可能会选择忽略或检查警告信息。
为捕获特定的错误条件,Excel Calculation Services 警告具有关联的错误代码。 然后 Web 服务将使用
SoapException
类中的属性返回错误。
有关详细信息,请参阅 Microsoft .NET Framework SDK 文档中的"SoapException 类"主题。
如果您的应用程序(即您的 SOAP 客户端)向 Web 服务发送一个服务无法处理的请求,服务将向客户端返回 SOAP 异常。 处理 Excel Web Services 抛出的异常是您开发的应用程序的一个重要部分,因为您可以在发生错误时向用户返回具体的信息。 异常处理也有助于改进当应用程序中发生意外事件时的用户体验。
有关异常处理的一般信息,请参阅 Microsoft .NET Framework SDK 文档中的"处理和抛出异常"。
访问 SOAP API
Excel Services 错误代码
步骤 3:访问 Web 服务
步骤 4:构建和测试应用程序
演练:使用 Excel Web Services 开发自定义应用程序