1

恐ろしい「client found response content type of "text/html" but expected "test/xml"」エラーが発生しましたが、グーグルで検索した後、SoapException を返す方法に関するこの投稿を見つけました。

だから私は先に進んでそれを実装しましたが、今でも同じエラーが発生しています。SoapException を受け入れることができるようにクライアント側で行う必要がある変更はありますか (私はそうは思いません。すべてが Exception から継承されているだけですよね?)

なぜ私はまだクライアント側でその恐ろしい応答を得ているのですか?

    [WebMethod]
    [SoapHeader("authenticationHeader")]
    [WebServiceAuthentication(AuthenticationRequired = false)]
    public DataSet GetConversionErrors()
    {
        try
        {
            return Components.PWD.GetConversionErrors();
        }
        catch (Exception ex)
        {
            PublishingManager.Publish(ex, HttpContext.Current.User.Identity.Name);
            throw Components.SoapException.GenerateSoapException(ex, Context);
        }
    }

編集: この catch ブロックの例外はまさに私が確認する必要があるものであることはわかっていますが、クライアント側でまだ System.InvalidOperationException を取得しています。

Edit2:それが役立つ/重要な場合は、WebReference(* .asmxファイルを呼び出す)を介してWebサービスに接続しています。

Edit3: サーバー側の例外ログに書き込まれる内容は次のとおりです (PublishingManager.Publish() 呼び出しで)。私の考えでは、これはクライアントに返されるものでなければなりません...

Exception Details:
Exception Type: System.Exception
Message: Test the text/html text/xml message. 
Method: PWD.Components.PWD.GetConversionErrors 
Username: xxxxxx Created 5/22/2012 4:20:53 PM 
Application: xxxx Application Identity: NT AUTHORITY\IUSR 
Source: xxxx Severity 2 
Machine: xxxxxxxxx IP Address 127.0.0.1 
AppDomain /LM/W3SVC/1/ROOT-1-129821937733610609 
Stack Trace    at PWD.Components.PWD.GetConversionErrors() in C:\Vault\Development-New\Web\Main_Logging\PWD\Components\PWD.cs:line 73 
   at PWD.PWD.GetConversionErrors() in C:\Vault\Development-New\Web\Main_Logging\PWD\PWD.asmx.cs:line 44 
Additional Information:
  +System.Exception: 
    Message: Test the text/html text/xml message. 
    Data: System.Collections.ListDictionaryInternal 
    InnerException:  
    TargetSite: System.Data.DataSet GetConversionErrors() 
    StackTrace:    at PWD.Components.PWD.GetConversionErrors() in C:\Vault\Development-New\Web\Main_Logging\PWD\Components\PWD.cs:line 73 
   at PWD.PWD.GetConversionErrors() in C:\Vault\Development-New\Web\Main_Logging\PWD\PWD.asmx.cs:line 44 
    HelpLink:  
    Source: xxxx 
     UserName: xxxxxxx 
     TypeName: PublishingManager 
     MachineName: xxxxxxxxx 
     TimeStamp: 5/22/2012 4:20:54 PM 
     FullName: Services.Publishing, Version=3.5.0.0, Culture=neutral, PublicKeyToken=null 
     AppDomainName: /LM/W3SVC/1/ROOT-1-129821937733610609 
     ThreadIdentity:  
     WindowsIdentity: NT AUTHORITY\IUSR 
     Severity: 2 
     MachineIPAddress: 127.0.0.1 

Edit3: この余分なコード チャンクを投げて、私がこれらの例外をどのようにテストしているかを人々に見てもらいたいだけです (そして、テストする方法が間違っているかもしれません...)。最初のコード チャンクでは、try ブロック内で "return Components.PWD.GetConversionErrors();" を呼び出しています。そのメソッドは次のとおりです。

    public static DataSet GetConversionErrors()
    {
        DB db = new DB();

        try
        {
            //return db.ExecuteDataset(Configuration.GenericConfig.AppConnectionString, CommandType.Text, spGetConversionErrors);
            throw new Exception("Test the text/html text/xml message.");
        }
        catch
        {
            throw;
        }
    }

ご覧のとおり、実際の呼び出しをコメントアウトし、テスト目的で毎回例外をスローする独自の行を挿入しました...

Edit4: @gbvb これが新しいメソッドです:

    [WebMethod]
    [SoapHeader("authenticationHeader")]
    [WebServiceAuthentication(AuthenticationRequired = false)]
    public DataSet GetConversionErrors()
    {
        try
        {
            return Components.PWD.GetConversionErrors();
        }
        catch (Exception ex)
        {
            //PublishingManager.Publish(ex, HttpContext.Current.User.Identity.Name);
            //throw Components.SoapException.GenerateSoapException(ex, Context);

            System.Xml.XmlDocument xmlDoc = new System.Xml.XmlDocument();
            System.Xml.XmlNode detailNode = xmlDoc.CreateNode(System.Xml.XmlNodeType.Element, System.Web.Services.Protocols.SoapException.DetailElementName.Name, System.Web.Services.Protocols.SoapException.DetailElementName.Namespace);
            detailNode.InnerText = ex.ToString();

            throw new System.Web.Services.Protocols.SoapException(ex.Message, System.Web.Services.Protocols.SoapException.ClientFaultCode, System.Web.HttpContext.Current.Request.Url.AbsoluteUri, detailNode, ex.InnerException);
        }
    }

Edit5: Fiddler2 が見たもの:

HTTP/1.1 500 Internal Server Error
Cache-Control: private
Content-Type: text/html
Server: Microsoft-IIS/7.5
X-Powered-By: ASP.NET
Date: Wed, 23 May 2012 19:25:56 GMT
Content-Length: 1208

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"/>
<title>500 - Internal server error.</title>
<style type="text/css">
<!--
body{margin:0;font-size:.7em;font-family:Verdana, Arial, Helvetica, sans-serif;background:#EEEEEE;}
fieldset{padding:0 15px 10px 15px;} 
h1{font-size:2.4em;margin:0;color:#FFF;}
h2{font-size:1.7em;margin:0;color:#CC0000;} 
h3{font-size:1.2em;margin:10px 0 0 0;color:#000000;} 
#header{width:96%;margin:0 0 0 0;padding:6px 2% 6px 2%;font-family:"trebuchet MS", Verdana, sans-serif;color:#FFF;
background-color:#555555;}
#content{margin:0 0 0 2%;position:relative;}
.content-container{background:#FFF;width:96%;margin-top:8px;padding:10px;position:relative;}
-->
</style>
</head>
<body>
<div id="header"><h1>Server Error</h1></div>
<div id="content">
 <div class="content-container"><fieldset>
  <h2>500 - Internal server error.</h2>
  <h3>There is a problem with the resource you are looking for, and it cannot be displayed.</h3>
 </fieldset></div>
</div>
</body>
</html>

誰かがこのセクションを適切にフォーマットする方法を知っている場合は、そうしてください:)

4

2 に答える 2

1

それで、私はそれを働かせました。これが私が見つけたものです:

IIS で Web サイトのプロパティを表示し、[モジュール] を選択すると、Web サイト/Web サービスによってスローされたエラーを処理しようとしている「CustomErrorModule」というエントリがあります。

修正は、そのエントリ「CustomErrorModule」を削除するか、次の構成ファイルを更新することです。

<httpErrors errorMode="Custom" existingResponse="Replace">

に:

<httpErrors errorMode="Custom" existingResponse="Auto">

助けてくれてありがとう、それは私を正しい方向に導きました。(ところで、私は設定ファイルを更新しているので、モジュールのものをいじる必要はありません)

また、この状況を説明するリンクを次に示します。

于 2012-06-13T21:20:54.843 に答える
0

笑いのために、その呼び出しからの型として SoapException.ClientFaultCode を使用して、明示的に new SoapException() をスローしてみてください。明らかに、上に示したコードには失敗する可能性のあるレイヤーがいくつかあり、簡単に台無しになります (信じてください、私は知っています:))。また、Publisher.publish などの他のメソッドを呼び出さないでください。これは、メッセージ宣言 (つまり、ASMX インフラストラクチャ) であるか、例外をいじっているコードであるかを示します。

于 2012-05-23T13:06:02.017 に答える