Silverlightクライアントコードで正常にキャッチしようとしていない例外をスローするWCFサービスがあります。デバッグの目的で宣言されていない障害を使用しています。これが私のサービス方法です。
[OperationContract]
public ServiceResponse MyWCFServiceMethod()
{
ServiceResponse resp = new ServiceResponse ();
//code for setting resp...
//purposely throw error here.
throw new FaultException(new FaultReason(new FaultReasonText("My fault Reason!")),new FaultCode("my fault code here"));
return resp;
}
今、私のSilverlightクライアントビューモデルでは、サービスのコールバックメソッドで、次のように処理しようとしています。
private void MyServiceCallback(MyWCFServiceMethodCompletedEventArgs e)
{
if (e.Error == null)
{
//proceed normally
}
else if (e.Error is FaultException)
{
FaultException<ExceptionDetail> fault = e.Error as FaultException<ExceptionDetail>;
MessageBox.Show(fault.Detail.Message);
MessageBox.Show(fault.Reason.ToString());
}
}
この行else if (e.Error is FaultException)
では、まだSystem.Net.WebExceptionが発生します{リモートサーバーがエラーを返しました:NotFound。}
これらは構成エントリです
<serviceMetadata httpGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="true" />
これはサービスクラス宣言です
[ServiceContract(Namespace = "")]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
public class MySilverlightWCFService
{
....
このサービスは、同じSilverlightソリューション内の別のプロジェクトにあります。Silverlightクライアントがスローしている障害例外を取得できないのはなぜですか?
御時間ありがとうございます...