[英]WCF and error handling , best practices
我有一個理論上的問題。 我有一個WCF Web服務,需要與.NET客戶端和iPhone應用程序進行通信。
在服務中,我有很多方法,例如:
User Login(string email,string password); etc..
如果成功,我希望該服務將我返回給用戶。 否則,我希望該服務向我拋出一個自定義異常,例如EmailNotFoundException
或PasswordNotCorrectException
。
有人告訴我這不是最好的方法,特別是因為iPhone客戶端將使用此服務。
我是否應該更改所有方法以返回將包含Object
和錯誤字符串/ Exception對象的WrapperEntity
?
這對我很重要,因為有時我需要知道操作失敗的原因。 如果Login
返回null,我將知道操作失敗,但我不知道為什么。
您不應在WCF服務中使用異常來定期與服務的使用者進行通信。 相反,請看一下創建一個響應對象,其中包含您需要了解的有關操作的所有信息。
就像是:
public class LoginResponse
{
public User User { get; set; }
public string Message { get; set; }
public bool IsSuccessful
{
get { return User != null; }
}
}
然后您的登錄操作將類似於:
LoginResponse Login(string email, string password)
{ ... }
這樣,如果操作失敗,則可以在響應中放入一條消息以說明原因。
http://msdn.microsoft.com/zh-cn/library/ms752208.aspx是錯誤處理的“真” WCF方法,但可能不適用於您的情況。 您可以使用錯誤代碼或某種Error類實例作為響應字段,如果成功,則為null ...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.